bills_lib_interfaces.js 112 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082
  1. /**
  2. * Created by vian on 2017/3/20.
  3. */
  4. const mongoose = require('mongoose');
  5. let counter = require("../../../public/counter/counter");
  6. let async = require("async");
  7. let StdBillsLib = mongoose.model('std_bills_lib_list');
  8. let Bills = mongoose.model('std_bills_lib_bills');
  9. let JobContent = mongoose.model('std_bills_lib_jobContent');
  10. let ItemCharacter = mongoose.model('std_bills_lib_itemCharacter');
  11. let moment = require("moment");
  12. let billsLibDao = function(){};
  13. billsLibDao.prototype.getMaxNumber = function(gData, callback){
  14. let billsLibId = gData.billsLibId;
  15. let field = gData.field;
  16. if(field === 'jobs'){
  17. JobContent.find({billsLibId: billsLibId, deleted: false}).sort({code: -1}).limit(1).exec(function(err, result){
  18. if(err){
  19. callback(1, 'Error', null);
  20. }
  21. else {
  22. callback(0, '', result);
  23. }
  24. });
  25. }
  26. else if(field === 'items'){
  27. ItemCharacter.find({billsLibId: billsLibId, deleted: false}).sort({code: -1}).limit(1).exec(function(err, result){
  28. if(err){
  29. callback(1, 'Error', null);
  30. }
  31. else {
  32. callback(0, '', result);
  33. }
  34. });
  35. }
  36. };
  37. //----------StdBillsLib-------------------
  38. billsLibDao.prototype.getABillsLib = function(data, callback){
  39. let billsLibId = data.billsLibId;
  40. StdBillsLib.find({billsLibId: billsLibId, deleted: false}, function(err, data){
  41. if(err){
  42. callback(1, 'Error', null);
  43. }
  44. else {
  45. callback(0, '', data);
  46. }
  47. });
  48. };
  49. billsLibDao.prototype.getStdBillsLib = function(callback){
  50. // let userId = data.userId;
  51. StdBillsLib.find({deleted: false}, "-_id", function(err, data){
  52. if(err){
  53. callback(1, "Error", null);
  54. }
  55. else{
  56. callback(0, "", data);
  57. }
  58. });
  59. };
  60. billsLibDao.prototype.createStdBillsLib = function(clibData, callback){
  61. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib, 1, function(err, result){
  62. let billsLibId = result.sequence_value;
  63. let userAccount = clibData.userAccount;
  64. let billsLibName = clibData.name;
  65. let compilationId = clibData.compilationId;
  66. let compilationName = clibData.compilationName;
  67. let dateStr = moment().format('YYYY-MM-DD HH:mm:ss');
  68. let newStdBillsLib = {
  69. creator: userAccount,
  70. createDate: dateStr,
  71. recentOpr: [{operator: userAccount, operateDate: dateStr}],
  72. billsLibId: billsLibId,
  73. billsLibName: billsLibName,
  74. compilationId: compilationId,
  75. compilationName: compilationName,
  76. deleted: false
  77. };
  78. StdBillsLib.create(newStdBillsLib, function(err){
  79. if(err){
  80. callback(1, "Error", null);
  81. }
  82. else {
  83. StdBillsLib.find({billsLibId: billsLibId}, function(err, data){
  84. if(err){
  85. callback(1, "Error", null)
  86. }
  87. else {
  88. callback(0, "", data);
  89. }
  90. });
  91. }
  92. });
  93. });
  94. };
  95. function getNewOprArr(recentOprArr, oprtor, oprDate){
  96. let isExist = false;
  97. for(let i =0 ; i<recentOprArr.length; i++){
  98. if(recentOprArr[i].operator === oprtor){
  99. recentOprArr[i].operateDate = oprDate;
  100. isExist = true;
  101. }
  102. }
  103. if(!isExist){
  104. if(recentOprArr.length < 5){
  105. recentOprArr.push({operator: oprtor, operateDate: oprDate});
  106. }
  107. else if(recentOprArr.length === 5){
  108. recentOprArr.sort(function (a, b) {
  109. if(a.operateDate > b.operateDate){
  110. return -1;
  111. }else {
  112. return 1;
  113. }
  114. return 0;
  115. });
  116. recentOprArr.splice(recentOprArr.length -1, 1);
  117. recentOprArr.splice(0, 1, {operator: oprtor, operateDate: oprDate});
  118. }
  119. }
  120. return recentOprArr;
  121. }
  122. billsLibDao.prototype.deleteStdBillsLib = function(data, callback){
  123. let billsLibId = data.billsLibId, lastOperator = data.lastOperator,
  124. lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  125. async.parallel([
  126. function(cb){
  127. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  128. if(err){
  129. cb(err);
  130. }
  131. else{
  132. if(result.length > 0 ){
  133. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  134. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr, deleted: true}}, function(err){
  135. if(err){
  136. cb(err);
  137. }
  138. else{
  139. cb(null);
  140. }
  141. });
  142. }
  143. }
  144. });
  145. },
  146. function(cb){
  147. Bills.update({billsLibId: billsLibId, deleted: false}, {$set: {deleted: true}}, {upsert: false, multi: true}, function(err){
  148. cb(null);
  149. });
  150. },
  151. function(cb){
  152. JobContent.update({billsLibId: billsLibId, deleted: false}, {$set: {deleted: true}}, {upsert: false, multi: true}, function(err, result){
  153. cb(null);
  154. });
  155. },
  156. function(cb){
  157. ItemCharacter.update({billsLibId: billsLibId, deleted: false}, {$set: {deleted: true}}, {upsert: false, multi: true}, function(err){
  158. cb(null);
  159. })
  160. }
  161. ], function(err){
  162. if(err){
  163. callback(1, 'Error');
  164. }
  165. else {
  166. callback(0, '');
  167. }
  168. });
  169. };
  170. billsLibDao.prototype.renameStdBillsLib = function(renameData, callback){
  171. let billsLibId = renameData.id;
  172. let renameVal = renameData.value;
  173. let lastOperator = renameData.lastOperator;
  174. let lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  175. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  176. if(err){
  177. callback(0, '');
  178. }
  179. else{
  180. if(result.length > 0){
  181. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  182. StdBillsLib.update({billsLibId: billsLibId}, {$set:{billsLibName: renameVal, recentOpr: newRecentOpr}}, function(err){
  183. if(err){
  184. callback(1, "Error");
  185. }
  186. else{
  187. callback(0, "");
  188. }
  189. });
  190. }
  191. }
  192. })
  193. };
  194. billsLibDao.prototype.getStdBillsLibName = function(billsLibId, callback){
  195. StdBillsLib.find({billsLibId: billsLibId, deleted: false}, "-_id", function(err, data){
  196. if(err){
  197. callback(1, "Error", null);
  198. }
  199. else {
  200. callback(0, "", data);
  201. }
  202. });
  203. };
  204. billsLibDao.prototype.getCurrentUniqId = function(callback){
  205. counter.counterDAO.getCurrentID(counter.moduleName.billsLib, function(result, err){
  206. let id = result.sequence_value;
  207. if(err){
  208. callback(1, 'Error', null);
  209. }
  210. else{
  211. callback(0, '', id);
  212. }
  213. });
  214. }
  215. //----------------------------Bills---------------------
  216. billsLibDao.prototype.getBills = function (billsLibId, callback) {
  217. Bills.find({billsLibId: billsLibId, deleted: false}, "-_id", function(err, billsData){
  218. if(err){
  219. callback(1, "Error", null);
  220. }
  221. else{
  222. callback(0, "", billsData);
  223. }
  224. });
  225. }
  226. billsLibDao.prototype.createBills = function(cbillsData, callback){
  227. let newId = cbillsData.newId;
  228. let pid = cbillsData.ParentID;
  229. let nid = cbillsData.NextSiblingID;
  230. let billsLibId = cbillsData.billsLibId;
  231. let updatePreData = cbillsData.updatePreData;
  232. let sectionInfo = cbillsData.sectionInfo;
  233. let lastOperator = cbillsData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  234. let newBills = {
  235. ID: newId,
  236. ParentID: pid,
  237. NextSiblingID: nid,
  238. billsLibId: billsLibId,
  239. code: '',
  240. name: '',
  241. unit: '',
  242. ruleText: '',
  243. Expression: '',
  244. recharge:'',
  245. sectionInfo: sectionInfo,
  246. deleted: false
  247. };
  248. async.parallel([
  249. function(cb){
  250. Bills.create(newBills, function(err){
  251. if(err){
  252. cb(err);
  253. }
  254. else {
  255. cb(null);
  256. }
  257. });
  258. },
  259. function(cb){
  260. if(updatePreData){
  261. Bills.findOneAndUpdate({billsLibId: billsLibId, ID: updatePreData.ID, deleted: false}, {$set: {NextSiblingID: updatePreData.NextSiblingID}}, function(err, result){
  262. if(err){
  263. cb(err);
  264. }
  265. else {
  266. cb(null)
  267. }
  268. });
  269. }
  270. else {
  271. cb(null);
  272. }
  273. },
  274. function (cb) {
  275. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  276. if(err){
  277. cb(err);
  278. }
  279. else{
  280. if(result.length > 0 ){
  281. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  282. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  283. if(err){
  284. cb(err);
  285. }
  286. else{
  287. cb(null);
  288. }
  289. });
  290. }
  291. }
  292. });
  293. }
  294. ], function(err){
  295. if(err){
  296. callback(1, 'Error');
  297. }
  298. else {
  299. callback(0, '');
  300. }
  301. });
  302. };
  303. billsLibDao.prototype.upMove = function(data, callback){
  304. let billsLibId = data.billsLibId,
  305. updateDatas = data.updateDatas,
  306. lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  307. async.parallel([
  308. function (cb) {
  309. async.each(updateDatas, function(updateData, ecb){
  310. Bills.findOneAndUpdate({billsLibId: billsLibId, ID: updateData.ID, deleted: false}, {$set: {NextSiblingID: updateData.NextSiblingID}}, function(err){
  311. if(err){
  312. ecb(err);
  313. }
  314. else {
  315. ecb(null);
  316. }
  317. });
  318. }, function(err){
  319. if(err){
  320. cb(err);
  321. }
  322. else{
  323. cb(null);
  324. }
  325. });
  326. },
  327. function (cb) {
  328. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  329. if(err){
  330. cb(err);
  331. }
  332. else{
  333. if(result.length > 0 ){
  334. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  335. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  336. if(err){
  337. cb(err);
  338. }
  339. else{
  340. cb(null);
  341. }
  342. });
  343. }
  344. }
  345. });
  346. }
  347. ], function (err) {
  348. if(err){
  349. callback(1, 'Error');
  350. }
  351. else{
  352. callback(0, '');
  353. }
  354. });
  355. };
  356. billsLibDao.prototype.downMove = function (data, callbck) {
  357. let billsLibId = data.billsLibId,
  358. updateDatas = data.updateDatas,
  359. functions = [], lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  360. let parallelFucs = {
  361. updateLastOpr: function () {
  362. return function (cb) {
  363. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  364. if(err){
  365. cb(err);
  366. }
  367. else{
  368. if(result.length > 0 ){
  369. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  370. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  371. if(err){
  372. cb(err);
  373. }
  374. else{
  375. cb(null);
  376. }
  377. });
  378. }
  379. }
  380. });
  381. }
  382. },
  383. nextSiblingNode: function (data) {
  384. return function (cb) {
  385. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {NextSiblingID: data.NextSiblingID}}, function (err) {
  386. if(err){
  387. cb(err);
  388. }
  389. else{
  390. cb(null);
  391. }
  392. });
  393. };
  394. },
  395. oprNode: function (data) {
  396. return function (cb) {
  397. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {NextSiblingID: data.NextSiblingID}}, function (err) {
  398. if(err){
  399. cb(err);
  400. }
  401. else {
  402. cb(null);
  403. }
  404. })
  405. }
  406. },
  407. preSiblingNode: function (data) {
  408. return function (cb) {
  409. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {NextSiblingID: data.NextSiblingID}}, function (err) {
  410. if(err){
  411. cb(err);
  412. }
  413. else{
  414. cb(null);
  415. }
  416. });
  417. };
  418. }
  419. };
  420. for(let i =0; i< updateDatas.length; i++){
  421. if(updateDatas[i].type === 'nextSiblingNode'){
  422. functions.push(parallelFucs.nextSiblingNode(updateDatas[i]));
  423. }
  424. else if(updateDatas[i].type === 'oprNode'){
  425. functions.push(parallelFucs.oprNode(updateDatas[i]));
  426. }
  427. else {
  428. functions.push(parallelFucs.preSiblingNode(updateDatas[i]));
  429. }
  430. }
  431. functions.push(parallelFucs.updateLastOpr());
  432. async.parallel(functions, function (err) {
  433. if(err){
  434. callbck(1, 'Error');
  435. }
  436. else{
  437. callbck(0, '');
  438. }
  439. })
  440. }
  441. billsLibDao.prototype.upLevel = function(data, callback){
  442. let billsLibId = data.billsLibId,
  443. updateDatas = data.updateDatas, functions = [],
  444. lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  445. let parallelFucs = {
  446. updateLastOpr: function () {
  447. return function (cb) {
  448. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  449. if(err){
  450. cb(err);
  451. }
  452. else{
  453. if(result.length > 0 ){
  454. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  455. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  456. if(err){
  457. cb(err);
  458. }
  459. else{
  460. cb(null);
  461. }
  462. });
  463. }
  464. }
  465. });
  466. }
  467. },
  468. oprNode: function (data) {
  469. return function (cb){
  470. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {ParentID: data.ParentID, NextSiblingID: data.NextSiblingID, sectionInfo: data.sectionInfo?data.sectionInfo:null}}, function(err){
  471. if(err){
  472. cb(err);
  473. }
  474. else {
  475. cb(null);
  476. }
  477. });
  478. };
  479. },
  480. parentNode: function (data) {
  481. return function(cb){
  482. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {NextSiblingID: data.NextSiblingID}}, function (err) {
  483. if(err){
  484. cb(err);
  485. }
  486. else {
  487. cb(null);
  488. }
  489. })
  490. };
  491. },
  492. nextSiblingNode: function (data) {
  493. return function (cb) {
  494. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {ParentID: data.ParentID, sectionInfo: data.sectionInfo}}, function (err) {
  495. if(err){
  496. cb(err);
  497. }
  498. else{
  499. cb(null);
  500. }
  501. });
  502. };
  503. },
  504. preSiblingNode: function(data){
  505. return function (cb) {
  506. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {NextSiblingID: data.NextSiblingID}}, function (err) {
  507. if(err){
  508. cb(err);
  509. }
  510. else {
  511. cb(null);
  512. }
  513. });
  514. };
  515. }
  516. }
  517. for(let i=0; i< updateDatas.length; i++){
  518. if(updateDatas[i].type === 'oprNode'){
  519. functions.push(parallelFucs.oprNode(updateDatas[i]));
  520. }
  521. else if(updateDatas[i].type === 'parentNode'){
  522. functions.push(parallelFucs.parentNode(updateDatas[i]));
  523. }
  524. else if(updateDatas[i].type === 'nextSiblingNode'){
  525. updateDatas[i].ID.forEach(function (id) {
  526. let obj = {ID: id, ParentID: updateDatas[i].ParentID, sectionInfo: updateDatas[i].sectionInfo ? updateDatas[i].sectionInfo : null };
  527. functions.push(parallelFucs.nextSiblingNode(obj));
  528. });
  529. }
  530. else {
  531. functions.push(parallelFucs.preSiblingNode(updateDatas[i]));
  532. }
  533. }
  534. functions.push(parallelFucs.updateLastOpr());
  535. async.parallel(functions, function(err){
  536. if(err){
  537. callback(1, 'Error');
  538. }
  539. else{
  540. callback(0, '');
  541. }
  542. });
  543. };
  544. billsLibDao.prototype.downLevel = function (data, callback) {
  545. let billsLibId = data.billsLibId,
  546. updateDatas = data.updateDatas,
  547. functions = [], lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  548. let parallelFucs = {
  549. updateLastOpr: function () {
  550. return function (cb) {
  551. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  552. if(err){
  553. cb(err);
  554. }
  555. else{
  556. if(result.length > 0 ){
  557. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  558. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  559. if(err){
  560. cb(err);
  561. }
  562. else{
  563. cb(null);
  564. }
  565. });
  566. }
  567. }
  568. });
  569. }
  570. },
  571. preSiblingNode: function (data) {
  572. return function (cb) {
  573. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {NextSiblingID: data.NextSiblingID}}, function (err) {
  574. if(err){
  575. cb(err);
  576. }
  577. else {
  578. cb(null);
  579. }
  580. });
  581. };
  582. },
  583. oprNode: function (data) {
  584. return function (cb) {
  585. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {ParentID: data.ParentID, NextSiblingID: data.NextSiblingID, sectionInfo: data.sectionInfo?data.sectionInfo:null}}, function (err) {
  586. if(err){
  587. cb(err);
  588. }
  589. else{
  590. cb(null);
  591. }
  592. });
  593. };
  594. },
  595. preChildren: function (data) {
  596. return function (cb) {
  597. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {NextSiblingID: data.NextSiblingID}}, function (err) {
  598. if(err){
  599. cb(err);
  600. }
  601. else{
  602. cb(null);
  603. }
  604. });
  605. };
  606. },
  607. oprChildren: function (data) {
  608. return function (cb) {
  609. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: {sectionInfo: data.sectionInfo?data.sectionInfo:null}}, function (err) {
  610. if(err){
  611. cb(err);
  612. }
  613. else{
  614. cb(null);
  615. }
  616. });
  617. };
  618. }
  619. }
  620. for(let i=0; i<updateDatas.length; i++){
  621. if(updateDatas[i].type === 'preSiblingNode'){
  622. functions.push(parallelFucs.preSiblingNode(updateDatas[i]));
  623. }
  624. else if(updateDatas[i].type === 'oprNode'){
  625. functions.push(parallelFucs.oprNode(updateDatas[i]));
  626. }
  627. else if(updateDatas[i].type === 'oprChildren'){
  628. functions.push(parallelFucs.oprChildren(updateDatas[i]));
  629. }
  630. else {
  631. functions.push(parallelFucs.preChildren(updateDatas[i]));
  632. }
  633. }
  634. functions.push(parallelFucs.updateLastOpr());
  635. async.parallel(functions, function (err) {
  636. if(err){
  637. callback(1, 'Error');
  638. }
  639. else{
  640. callback(0, '');
  641. }
  642. })
  643. };
  644. billsLibDao.prototype.updatePNId= function(upData, callback){
  645. let billsLibId = upData.billsLibId;
  646. let updateDatas = upData.updateData;
  647. let eachDatas = [];
  648. for(let i=0; i< updateDatas.length; i++){
  649. if(updateDatas[i].ID.length > 1){
  650. let ids = updateDatas[i].ID;
  651. for(let j=0; j<ids.length; j++){
  652. let eachObj = {
  653. id: ids[j],
  654. data: updateDatas[i]
  655. }
  656. eachDatas.push(eachObj);
  657. }
  658. }
  659. else {
  660. eachDatas.push({id: updateDatas[i].ID, data: updateDatas[i]});
  661. }
  662. }
  663. async.each(eachDatas, function(eachObj, cb){
  664. let id = eachObj.id, data = eachObj.data;
  665. if(data.ParentID && data.NextSiblingID){
  666. Bills.update({billsLibId: billsLibId, ID: id, deleted: false}, {$set: {ParentID: data.ParentID, NextSiblingID: data.NextSiblingID}}, function(err){
  667. if(err){
  668. cb(err);
  669. }else {
  670. cb(null);
  671. }
  672. });
  673. }
  674. else if(data.ParentID && !data.NextSiblingID){
  675. Bills.update({billsLibId: billsLibId, ID: id, deleted: false}, {$set: {ParentID: data.ParentID}}, function(err){
  676. if(err){
  677. if(err){
  678. cb(err);
  679. }else {
  680. cb(null);
  681. }
  682. }
  683. });
  684. }
  685. else if(!data.ParentID && data.NextSiblingID){
  686. Bills.update({billsLibId: billsLibId, ID: id, deleted: false}, {$set: {NextSiblingID: data.NextSiblingID}}, function(err){
  687. if(err){
  688. cb(err);
  689. }else {
  690. cb(null);
  691. }
  692. });
  693. }
  694. }, function(err){
  695. if(err){
  696. callback(1, 'Error');
  697. }
  698. else {
  699. callback(0, '');
  700. }
  701. });
  702. }
  703. billsLibDao.prototype.updateSectionInfo = function (data, callback) {
  704. let functions = [];
  705. let updateData = data.updateData;
  706. for(let ud of updateData){
  707. functions.push((function(udData){
  708. return function(cb){
  709. Bills.update({ID: udData.ID}, {$set: udData}, function(err){
  710. if(err){
  711. cb(err);
  712. }
  713. else{
  714. cb(null);
  715. }
  716. });
  717. };
  718. })(ud));
  719. }
  720. async.parallel(functions, function(err, results) {
  721. let errCode = 0,
  722. errMsg = '';
  723. if(err){
  724. errCode = 1;
  725. errMsg = 'Error'
  726. }
  727. callback(errCode, errMsg);
  728. });
  729. };
  730. billsLibDao.prototype.updateBills = function(ubillsData, callback){
  731. let billsLibId = ubillsData.billsLibId;
  732. let updateId = ubillsData.updateId;
  733. let updateField = ubillsData.field;
  734. let updateData = ubillsData.data, lastOperator = ubillsData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  735. let needSet = {};
  736. needSet[updateField] = updateData;
  737. async.parallel([
  738. function (cb) {
  739. if(updateField !== 'jobs' && updateField !== 'items'){
  740. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$set: needSet}, function (err) {
  741. if(err){
  742. cb(err);
  743. }
  744. else{
  745. cb(null);
  746. }
  747. })
  748. }
  749. else{
  750. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$addToSet: needSet}, function (err) {
  751. if(err){
  752. cb(err);
  753. }
  754. else{
  755. cb(null);
  756. }
  757. });
  758. }
  759. },
  760. function (cb) {
  761. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  762. if(err){
  763. cb(err);
  764. }
  765. else{
  766. if(result.length > 0 ){
  767. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  768. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  769. if(err){
  770. cb(err);
  771. }
  772. else{
  773. cb(null);
  774. }
  775. });
  776. }
  777. }
  778. });
  779. }
  780. ], function (err) {
  781. if(err){
  782. callback(1, 'Error');
  783. }
  784. else{
  785. callback(0, '');
  786. }
  787. });
  788. }
  789. billsLibDao.prototype.removeTotal = function (data, callback) {
  790. let billsLibId = data.billsLibId, billsIds = data.billsIds,
  791. delIds = data.delIds, field = data.field, functions = [], delArr = [],
  792. lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  793. if(billsIds.length > 0){
  794. billsIds.forEach(function (updateId) {
  795. delIds.forEach(function (delId) {
  796. delArr.push({updateID: updateId, delId: delId});
  797. });
  798. });
  799. }
  800. let parallelFucs = {
  801. updateLastOpr: function () {
  802. return function (cb) {
  803. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  804. if(err){
  805. cb(err);
  806. }
  807. else{
  808. if(result.length > 0 ){
  809. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  810. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  811. if(err){
  812. cb(err);
  813. }
  814. else{
  815. cb(null);
  816. }
  817. });
  818. }
  819. }
  820. });
  821. }
  822. },
  823. delJobs: function () {
  824. return function (cb) {
  825. async.each(delIds, function (delJobId, ecb) {
  826. JobContent.update({billsLibId: billsLibId, id: delJobId, deleted: false}, {$set: {deleted: true}}, function (err, result) {
  827. if(err){
  828. ecb(err);
  829. }
  830. else {
  831. ecb(null);
  832. }
  833. });
  834. }, function (err) {
  835. if(err){
  836. cb(err);
  837. }
  838. else{
  839. cb(null);
  840. }
  841. });
  842. };
  843. },
  844. delJobsArr: function () {
  845. return function (cb) {
  846. async.each(delArr, function (delObj, ecb) {
  847. console.log(`delObj`);
  848. console.log(delObj);
  849. Bills.update({billsLibId: billsLibId, ID: delObj.updateID, deleted: false}, {$pull: {jobs: {id: delObj.delId}}}, function (err) {
  850. if(err){
  851. ecb(err);
  852. }else{
  853. ecb(null);
  854. }
  855. });
  856. }, function (err) {
  857. if(err){
  858. cb(err);
  859. }
  860. else{
  861. cb(null);
  862. }
  863. })
  864. };
  865. },
  866. delItems: function () {
  867. return function (cb) {
  868. async.each(delIds, function (delItemId, ecb) {
  869. ItemCharacter.update({billsLibId: billsLibId, id: delItemId, deleted: false}, {$set: {deleted: true}}, function (err) {
  870. if(err){
  871. ecb(err);
  872. }
  873. else{
  874. ecb(null);
  875. }
  876. }, function (err) {
  877. if(err){
  878. cb(err);
  879. }
  880. else{
  881. cb(null);
  882. }
  883. });
  884. });
  885. }
  886. },
  887. delItemsArr: function () {
  888. return function (cb) {
  889. async.each(delArr, function (delObj, ecb) {
  890. Bills.update({billsLibId: billsLibId, ID: delObj.updateID, deleted:false}, {$pull: {items: {id: delObj.delId}}}, function(err){
  891. if(err){
  892. ecb(err);
  893. }
  894. else{
  895. ecb(null);
  896. }
  897. });
  898. }, function (err) {
  899. if(err){
  900. cb(err);
  901. }
  902. else{
  903. cb(null);
  904. }
  905. });
  906. }
  907. }
  908. };
  909. if(field === 'jobs'){
  910. functions.push(parallelFucs.delJobs());
  911. functions.push(parallelFucs.delJobsArr());
  912. }
  913. else{
  914. functions.push(parallelFucs.delItems());
  915. functions.push(parallelFucs.delItemsArr());
  916. }
  917. functions.push(parallelFucs.updateLastOpr());
  918. async.parallel(functions, function (err) {
  919. if(err){
  920. callback(1, 'Error');
  921. }
  922. else{
  923. callback(0, '');
  924. }
  925. });
  926. };
  927. billsLibDao.prototype.updateSerialNo = function (data, callback) {
  928. let billsLibId = data.billsLibId, billsId = data.billsId,
  929. updateArr = data.updateArr, field = data.field,
  930. lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  931. if(field === 'jobs'){
  932. async.parallel([
  933. function (cb) {
  934. async.each(updateArr, function (updateObj, ecb) {
  935. Bills.update({billsLibId: billsLibId, ID: billsId, deleted: false, 'jobs.id': updateObj.id}, {$set: {'jobs.$.serialNo': updateObj.serialNo}}, function (err) {
  936. if(err){
  937. ecb(err);
  938. }
  939. else{
  940. ecb(null);
  941. }
  942. });
  943. }, function (err) {
  944. if(err){
  945. cb(err);
  946. }
  947. else{
  948. cb(null);
  949. }
  950. });
  951. },
  952. function (cb) {
  953. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  954. if(err){
  955. cb(err);
  956. }
  957. else{
  958. if(result.length > 0 ){
  959. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  960. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  961. if(err){
  962. cb(err);
  963. }
  964. else{
  965. cb(null);
  966. }
  967. });
  968. }
  969. }
  970. });
  971. }
  972. ], function (err) {
  973. if(err){
  974. callback(1, 'Error');
  975. }
  976. else{
  977. callback(0, '');
  978. }
  979. });
  980. }
  981. else{
  982. async.parallel([
  983. function (cb) {
  984. async.each(updateArr, function (updateObj, ecb) {
  985. Bills.update({billsLibId: billsLibId, ID: billsId, deleted: false, 'items.id': updateObj.id}, {$set: {'items.$.serialNo': updateObj.serialNo}}, function (err) {
  986. if(err){
  987. ecb(err);
  988. }
  989. else{
  990. ecb(null);
  991. }
  992. });
  993. }, function (err) {
  994. if(err){
  995. cb(err);
  996. }
  997. else{
  998. cb(null);
  999. }
  1000. });
  1001. },
  1002. function (cb) {
  1003. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1004. if(err){
  1005. cb(err);
  1006. }
  1007. else{
  1008. if(result.length > 0 ){
  1009. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1010. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1011. if(err){
  1012. cb(err);
  1013. }
  1014. else{
  1015. cb(null);
  1016. }
  1017. });
  1018. }
  1019. }
  1020. });
  1021. }
  1022. ], function (err) {
  1023. if(err){
  1024. callback(1, 'Error');
  1025. }
  1026. else{
  1027. callback(0, '');
  1028. }
  1029. });
  1030. }
  1031. };
  1032. billsLibDao.prototype.updateBillsArr = function(updateData, callback){
  1033. let billsLibId = updateData.billsLibId;
  1034. let updateId = updateData.updateId;
  1035. let orgId = updateData.orgId;
  1036. let newId = updateData.newId;
  1037. let classify = updateData.classify;
  1038. let type = updateData.type;
  1039. let lastOperator = updateData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  1040. if(classify === 'jobs'){
  1041. if(orgId && newId && type === 'update'){
  1042. async.parallel([
  1043. function (cb) {
  1044. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false, 'jobs.id': orgId}, {$set: {'jobs.$.id': newId}}, function(err){
  1045. if(err){
  1046. cb(err);
  1047. }
  1048. else {
  1049. cb(null);
  1050. }
  1051. });
  1052. },
  1053. function (cb) {
  1054. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1055. if(err){
  1056. cb(err);
  1057. }
  1058. else{
  1059. if(result.length > 0 ){
  1060. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1061. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1062. if(err){
  1063. cb(err);
  1064. }
  1065. else{
  1066. cb(null);
  1067. }
  1068. });
  1069. }
  1070. }
  1071. });
  1072. }
  1073. ], function (err) {
  1074. if(err){
  1075. callback(1, 'Error');
  1076. }
  1077. else{
  1078. callback(0, '');
  1079. }
  1080. });
  1081. }
  1082. if(orgId && !newId && type === 'delete'){
  1083. async.parallel([
  1084. function (cb) {
  1085. async.each(orgId, function(oid, ecb){
  1086. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$pull: {jobs: {id: oid}}}, function(err){
  1087. if(err){
  1088. ecb(err);
  1089. }else {
  1090. ecb(null);
  1091. }
  1092. });
  1093. }, function(err){
  1094. if(err){
  1095. cb(err);
  1096. }
  1097. else{
  1098. cb(null);
  1099. }
  1100. });
  1101. },
  1102. function (cb) {
  1103. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1104. if(err){
  1105. cb(err);
  1106. }
  1107. else{
  1108. if(result.length > 0 ){
  1109. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1110. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1111. if(err){
  1112. cb(err);
  1113. }
  1114. else{
  1115. cb(null);
  1116. }
  1117. });
  1118. }
  1119. }
  1120. });
  1121. }
  1122. ], function (err) {
  1123. if(err){
  1124. callback(1, 'Error');
  1125. }
  1126. else{
  1127. callback(0, '');
  1128. }
  1129. })
  1130. }
  1131. if(orgId && !newId && type === 'deleteAll'){
  1132. let delArr = [];
  1133. updateId.forEach(function(uid){
  1134. orgId.forEach(function(oid){
  1135. delArr.push({updateId: uid, delId: oid});
  1136. });
  1137. });
  1138. async.parallel([
  1139. function (cb) {
  1140. async.each(delArr, function(delObj, ecb){
  1141. Bills.update({billsLibId: billsLibId, ID: delObj.updateId, deleted: false}, {$pull: {jobs: {id: delObj.delId}}}, function(err){
  1142. if(err){
  1143. ecb(err);
  1144. }else {
  1145. ecb(null);
  1146. }
  1147. });
  1148. }, function(err){
  1149. if(err){
  1150. cb(err);
  1151. }else {
  1152. cb(null);
  1153. }
  1154. });
  1155. },
  1156. function (cb) {
  1157. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1158. if(err){
  1159. cb(err);
  1160. }
  1161. else{
  1162. if(result.length > 0 ){
  1163. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1164. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1165. if(err){
  1166. cb(err);
  1167. }
  1168. else{
  1169. cb(null);
  1170. }
  1171. });
  1172. }
  1173. }
  1174. });
  1175. }
  1176. ], function (err) {
  1177. if(err){
  1178. callback(1, 'Error');
  1179. }
  1180. else{
  1181. callback(0, '');
  1182. }
  1183. });
  1184. }
  1185. }
  1186. else if(classify === 'items'){
  1187. if(orgId && newId && type === 'update'){
  1188. async.parallel([
  1189. function (cb) {
  1190. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false, 'items.id': orgId}, {$set: {'items.$.id': newId}}, function(err){
  1191. if(err){
  1192. cb(err);
  1193. }
  1194. else {
  1195. cb(null);
  1196. }
  1197. });
  1198. },
  1199. function (cb) {
  1200. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1201. if(err){
  1202. cb(err);
  1203. }
  1204. else{
  1205. if(result.length > 0 ){
  1206. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1207. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1208. if(err){
  1209. cb(err);
  1210. }
  1211. else{
  1212. cb(null);
  1213. }
  1214. });
  1215. }
  1216. }
  1217. });
  1218. }
  1219. ], function (err) {
  1220. if(err){
  1221. callback(1, 'Error');
  1222. }
  1223. else{
  1224. callback(0, '');
  1225. }
  1226. });
  1227. }
  1228. if(orgId && !newId && type === 'delete'){
  1229. async.parallel([
  1230. function (cb) {
  1231. async.each(orgId, function(oid, ecb){
  1232. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$pull: {items: {id: oid}}}, function(err){
  1233. if(err){
  1234. ecb(err);
  1235. }else {
  1236. ecb(null);
  1237. }
  1238. });
  1239. }, function(err){
  1240. if(err){
  1241. cb(err);
  1242. }else {
  1243. cb(null);
  1244. }
  1245. });
  1246. },
  1247. function (cb) {
  1248. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1249. if(err){
  1250. cb(err);
  1251. }
  1252. else{
  1253. if(result.length > 0 ){
  1254. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1255. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1256. if(err){
  1257. cb(err);
  1258. }
  1259. else{
  1260. cb(null);
  1261. }
  1262. });
  1263. }
  1264. }
  1265. });
  1266. }
  1267. ], function (err) {
  1268. if(err){
  1269. callback(1, 'Error');
  1270. }
  1271. else{
  1272. callback(0, '');
  1273. }
  1274. })
  1275. }
  1276. if(orgId && !newId && type === 'deleteAll'){
  1277. let delArr = [];
  1278. updateId.forEach(function(uid){
  1279. orgId.forEach(function(oid){
  1280. delArr.push({updateId: uid, delId: oid});
  1281. });
  1282. });
  1283. async.parallel([
  1284. function (cb) {
  1285. async.each(delArr, function(delObj, ecb){
  1286. Bills.update({billsLibId: billsLibId, ID: delObj.updateId, deleted: false}, {$pull: {items: {id: delObj.delId}}}, function(err){
  1287. if(err){
  1288. ecb(err);
  1289. }else {
  1290. ecb(null);
  1291. }
  1292. });
  1293. }, function(err){
  1294. if(err){
  1295. cb(err);
  1296. }else {
  1297. cb(err);
  1298. }
  1299. });
  1300. },
  1301. function (cb) {
  1302. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1303. if(err){
  1304. cb(err);
  1305. }
  1306. else{
  1307. if(result.length > 0 ){
  1308. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1309. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1310. if(err){
  1311. cb(err);
  1312. }
  1313. else{
  1314. cb(null);
  1315. }
  1316. });
  1317. }
  1318. }
  1319. });
  1320. }
  1321. ], function (err) {
  1322. if(err){
  1323. callback(1, 'Error');
  1324. }
  1325. else{
  1326. callback(0, '');
  1327. }
  1328. });
  1329. }
  1330. }
  1331. };
  1332. billsLibDao.prototype.pasteBills = function(pData, callback){
  1333. let datas = pData.datas,
  1334. billsLibId = pData.billsLibId, lastOperator = pData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  1335. async.parallel([
  1336. function (cb) {
  1337. async.each(datas, function(data, ecb){
  1338. let needSet = {};
  1339. for(let i in data){
  1340. needSet[i] = data[i];
  1341. }
  1342. Bills.update({billsLibId: billsLibId, ID: data.ID, deleted: false}, {$set: needSet}, function (err) {
  1343. if(err){
  1344. ecb(err);
  1345. }
  1346. else {
  1347. ecb(null);
  1348. }
  1349. });
  1350. }, function(err){
  1351. if(err){
  1352. cb(err);
  1353. }else {
  1354. cb(null);
  1355. }
  1356. });
  1357. },
  1358. function (cb) {
  1359. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1360. if(err){
  1361. cb(err);
  1362. }
  1363. else{
  1364. if(result.length > 0 ){
  1365. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1366. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1367. if(err){
  1368. cb(err);
  1369. }
  1370. else{
  1371. cb(null);
  1372. }
  1373. });
  1374. }
  1375. }
  1376. });
  1377. }
  1378. ], function (err) {
  1379. if(err){
  1380. callback(1, 'Error');
  1381. }
  1382. else{
  1383. callback(0, '');
  1384. }
  1385. });
  1386. }
  1387. billsLibDao.prototype.updateRecharge = function(uData, callback){
  1388. let billsLibId = uData.billsLibId;
  1389. let updateId = uData.updateId;
  1390. let data = uData.data, lastOperator = uData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  1391. async.parallel([
  1392. function (cb) {
  1393. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$set: {recharge: data}}, function(err){
  1394. if(err){
  1395. cb(err);
  1396. }
  1397. else {
  1398. cb(null);
  1399. }
  1400. });
  1401. },
  1402. function (cb) {
  1403. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1404. if(err){
  1405. cb(err);
  1406. }
  1407. else{
  1408. if(result.length > 0 ){
  1409. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1410. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1411. if(err){
  1412. cb(err);
  1413. }
  1414. else{
  1415. cb(null);
  1416. }
  1417. });
  1418. }
  1419. }
  1420. });
  1421. }
  1422. ], function (err) {
  1423. if(err){
  1424. callback(1, 'Error');
  1425. }
  1426. else{
  1427. callback(0, '');
  1428. }
  1429. });
  1430. };
  1431. billsLibDao.prototype.pasteRel = function (data, callback) {
  1432. const UpdateExist = 'updateExist', UpdateNew = 'updateNew', CreateExist = 'createExist', CreateNew = 'createNew';
  1433. const Jobs = 'jobs', Items = 'items';
  1434. let field = data.field;
  1435. let updateDatas = data.updateDatas;
  1436. let createDatas = data.createDatas;
  1437. let functions = [], lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  1438. let parallelFucs = {
  1439. updateLastOpr: function () {
  1440. return function (cb) {
  1441. StdBillsLib.find({billsLibId: data.billsLibId}, function (err, result) {
  1442. if(err){
  1443. cb(err);
  1444. }
  1445. else{
  1446. if(result.length > 0 ){
  1447. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1448. StdBillsLib.update({billsLibId: data.billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1449. if(err){
  1450. cb(err);
  1451. }
  1452. else{
  1453. cb(null);
  1454. }
  1455. });
  1456. }
  1457. }
  1458. });
  1459. }
  1460. },
  1461. updateExJobs: function(data){
  1462. let orgJobId = data.orgJobId, newJobId = data.newJobId,
  1463. nodeId = data.nodeId, billsLibId = data.billsLibId;
  1464. return function (cb){
  1465. if(orgJobId && newJobId && nodeId && billsLibId){
  1466. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false, 'jobs.id': orgJobId}, {$set: {'jobs.$.id': newJobId}}, function(err){
  1467. if(err){
  1468. cb(err);
  1469. }
  1470. else{
  1471. cb(null, data)
  1472. }
  1473. });
  1474. }
  1475. }
  1476. },
  1477. updateNeJobs: function(data){
  1478. let billsLibId = data.billsLibId, nodeId = data.nodeId, newData = data.newData,
  1479. orgJobId = data.orgJobId, code = data.code;
  1480. return function (cb){
  1481. if(billsLibId && nodeId && newData && orgJobId && code){
  1482. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  1483. if(err){
  1484. cb(err);
  1485. }
  1486. else {
  1487. let newJobId = result.sequence_value;
  1488. let newJobContent = {
  1489. id: newJobId,
  1490. billsLibId: billsLibId,
  1491. code: code,
  1492. content: newData,
  1493. deleted: false
  1494. };
  1495. JobContent.create(newJobContent, function(err){
  1496. if(err){
  1497. cb(err);
  1498. }
  1499. else{
  1500. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false, 'jobs.id': orgJobId}, {$set: {'jobs.$.id': newJobId}}, function(err){
  1501. if(err){
  1502. cb(err);
  1503. }
  1504. else{
  1505. data.newJobId = newJobId;
  1506. cb(null, data);
  1507. }
  1508. });
  1509. }
  1510. });
  1511. }
  1512. });
  1513. }
  1514. }
  1515. },
  1516. createExJobs: function(data){
  1517. let billsLibId = data.billsLibId, newData = data.newData,
  1518. nodeId = data.nodeId, jobId = data.jobId, serialNo = data.serialNo;
  1519. return function (cb){
  1520. if(billsLibId && newData && nodeId && jobId){
  1521. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false}, {$addToSet: {jobs: {id: jobId, serialNo: serialNo}}}, function(err){
  1522. if(err){
  1523. cb(err);
  1524. }
  1525. else {
  1526. cb(null, data);
  1527. }
  1528. });
  1529. }
  1530. }
  1531. },
  1532. createNeJobs: function(data){
  1533. let billsLibId = data.billsLibId, newData = data.newData,
  1534. code = data.code, nodeId = data.nodeId, serialNo = data.serialNo;
  1535. return function (cb){
  1536. if(billsLibId && newData && code){
  1537. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  1538. if(err){
  1539. cb(err);
  1540. }
  1541. else {
  1542. let newJobId = result.sequence_value;
  1543. let newJobContent = {
  1544. id: newJobId,
  1545. billsLibId: billsLibId,
  1546. code: code,
  1547. content: newData,
  1548. deleted: false
  1549. };
  1550. JobContent.create(newJobContent, function(err){
  1551. if(err){
  1552. cb(err);
  1553. }
  1554. else{
  1555. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false}, {$addToSet: {jobs: {id: newJobId, serialNo: serialNo}}}, function(err){
  1556. if(err){
  1557. cb(err);
  1558. }
  1559. else {
  1560. data.newJobId = newJobId;
  1561. cb(null, data);
  1562. }
  1563. });
  1564. }
  1565. });
  1566. }
  1567. });
  1568. }
  1569. }
  1570. },
  1571. updateExItems: function(data){
  1572. let orgItemId = data.orgItemId, newItemId = data.newItemId,
  1573. nodeId = data.nodeId, billsLibId = data.billsLibId;
  1574. return function (cb){
  1575. if(orgItemId && newItemId && nodeId && billsLibId){
  1576. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false, 'items.id': orgItemId}, {$set: {'items.$.id': newItemId}}, function(err){
  1577. if(err){
  1578. cb(err);
  1579. }
  1580. else{
  1581. cb(null, data);
  1582. }
  1583. });
  1584. }
  1585. }
  1586. },
  1587. updateNeItems: function(data){
  1588. let billsLibId = data.billsLibId, nodeId = data.nodeId, newData = data.newData,
  1589. orgItemId = data.orgItemId, code = data.code;
  1590. return function (cb){
  1591. if(billsLibId && nodeId && newData && orgItemId && code){
  1592. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function(err, result){
  1593. if(err){
  1594. cb(err);
  1595. }
  1596. else {
  1597. let newItemId = result.sequence_value;
  1598. let newItemContent = {
  1599. id: newItemId,
  1600. billsLibId: billsLibId,
  1601. code: code,
  1602. content: newData,
  1603. deleted: false
  1604. };
  1605. ItemCharacter.create(newItemContent, function(err){
  1606. if(err){
  1607. cb(err);
  1608. }
  1609. else{
  1610. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false, 'items.id': orgItemId}, {$set: {'items.$.id': newItemId}}, function(err){
  1611. if(err){
  1612. cb(err);
  1613. }
  1614. else{
  1615. data.newItemId = newItemId;
  1616. cb(null, data);
  1617. }
  1618. });
  1619. }
  1620. });
  1621. }
  1622. });
  1623. }
  1624. }
  1625. },
  1626. createExItems: function(data){
  1627. let billsLibId = data.billsLibId, newData = data.newData,
  1628. nodeId = data.nodeId, itemId = data.itemId, serialNo = data.serialNo;
  1629. return function (cb){
  1630. if(billsLibId && newData && nodeId && itemId){
  1631. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false}, {$addToSet: {items: {id: itemId, serialNo: serialNo}}}, function(err){
  1632. if(err){
  1633. cb(err);
  1634. }
  1635. else {
  1636. cb(null, data);
  1637. }
  1638. });
  1639. }
  1640. }
  1641. },
  1642. createNeItems: function(data){
  1643. let billsLibId = data.billsLibId, newData = data.newData,
  1644. code = data.code, nodeId = data.nodeId, serialNo = data.serialNo;
  1645. return function (cb){
  1646. if(billsLibId && newData && code){
  1647. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function(err, result){
  1648. if(err){
  1649. cb(err);
  1650. }
  1651. else {
  1652. let newItemId = result.sequence_value;
  1653. let newItemContent = {
  1654. id: newItemId,
  1655. billsLibId: billsLibId,
  1656. code: code,
  1657. content: newData,
  1658. deleted: false
  1659. };
  1660. ItemCharacter.create(newItemContent, function(err){
  1661. if(err){
  1662. cb(err);
  1663. }
  1664. else{
  1665. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false}, {$addToSet: {items: {id: newItemId, serialNo: serialNo}}}, function(err){
  1666. if(err){
  1667. cb(err);
  1668. }
  1669. else {
  1670. data.newItemId = newItemId;
  1671. cb(null, data);
  1672. }
  1673. });
  1674. }
  1675. });
  1676. }
  1677. });
  1678. }
  1679. }
  1680. }
  1681. };
  1682. if(field === Jobs){
  1683. if(updateDatas.length > 0){
  1684. for(let i=0; i<updateDatas.length; i++){
  1685. if(updateDatas[i].type === UpdateExist){
  1686. functions.push(parallelFucs.updateExJobs(updateDatas[i]));
  1687. }
  1688. if(updateDatas[i].type === UpdateNew){
  1689. functions.push(parallelFucs.updateNeJobs(updateDatas[i]));
  1690. }
  1691. }
  1692. }
  1693. if(createDatas.length > 0){
  1694. for(let i=0; i<createDatas.length; i++){
  1695. if(createDatas[i].type === CreateExist){
  1696. functions.push(parallelFucs.createExJobs(createDatas[i]));
  1697. }
  1698. if(createDatas[i].type === CreateNew){
  1699. functions.push(parallelFucs.createNeJobs(createDatas[i]));
  1700. }
  1701. }
  1702. }
  1703. }
  1704. else {
  1705. if(updateDatas.length > 0){
  1706. for(let i=0; i<updateDatas.length; i++){
  1707. if(updateDatas[i].type === UpdateExist){
  1708. functions.push(parallelFucs.updateExItems(updateDatas[i]));
  1709. }
  1710. if(updateDatas[i].type === UpdateNew){
  1711. functions.push(parallelFucs.updateNeItems(updateDatas[i]));
  1712. }
  1713. }
  1714. }
  1715. if(createDatas.length > 0){
  1716. for(let i=0; i<createDatas.length; i++){
  1717. if(createDatas[i].type === CreateExist){
  1718. functions.push(parallelFucs.createExItems(createDatas[i]));
  1719. }
  1720. if(createDatas[i].type === CreateNew){
  1721. functions.push(parallelFucs.createNeItems(createDatas[i]));
  1722. }
  1723. }
  1724. }
  1725. }
  1726. functions.push(parallelFucs.updateLastOpr());
  1727. async.parallel(functions, function(err, datas){
  1728. if(err){
  1729. callback(1, 'Error', null);
  1730. }else {
  1731. callback(0, '', datas);
  1732. }
  1733. });
  1734. };
  1735. billsLibDao.prototype.deleteBills = function(delData, callback){
  1736. let deleteIds = delData.deleteIds;
  1737. let billsLibId = delData.billsLibId;
  1738. let updateNode = delData.updateNode,
  1739. lastOperator = delData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  1740. if(deleteIds){
  1741. async.parallel([
  1742. function(cb){
  1743. async.each(deleteIds, function(delId, ecb){
  1744. Bills.update({billsLibId: billsLibId, ID: delId, deleted: false}, {$set: {deleted: true}}, function(err){
  1745. if(err){
  1746. ecb(err);
  1747. }
  1748. else {
  1749. ecb(null);
  1750. }
  1751. });
  1752. }, function(err){
  1753. if(err){
  1754. cb(err);
  1755. }
  1756. else {
  1757. cb(null);
  1758. }
  1759. });
  1760. },
  1761. function(cb){
  1762. if(updateNode){
  1763. Bills.update({billsLibId: billsLibId, ID: updateNode.ID, deleted: false}, {$set: {NextSiblingID: updateNode.NextSiblingID}}, function(err){
  1764. if(err){
  1765. cb(err);
  1766. }
  1767. else {
  1768. cb(null);
  1769. }
  1770. });
  1771. }else {
  1772. cb(null);
  1773. }
  1774. },
  1775. function (cb) {
  1776. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1777. if(err){
  1778. cb(err);
  1779. }
  1780. else{
  1781. if(result.length > 0 ){
  1782. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1783. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1784. if(err){
  1785. cb(err);
  1786. }
  1787. else{
  1788. cb(null);
  1789. }
  1790. });
  1791. }
  1792. }
  1793. });
  1794. }
  1795. ], function(err){
  1796. if(err){
  1797. callback(1, 'Error');
  1798. }else {
  1799. callback(0, '');
  1800. }
  1801. });
  1802. }
  1803. }
  1804. //--------------JobContent------------------
  1805. billsLibDao.prototype.getJobContent = function(gJobData, callback){
  1806. let billsLibId = gJobData.billsLibId;
  1807. JobContent.find({billsLibId: billsLibId, deleted: false}, '-_id').sort({code: 1}).exec(function(err, result){
  1808. if(err){
  1809. callback(1, 'Error', null);
  1810. }
  1811. else {
  1812. callback(0, '', result);
  1813. }
  1814. });
  1815. }
  1816. billsLibDao.prototype.createJobContent = function(cJobData, callback){
  1817. let data = cJobData.data;
  1818. let billsLibId = cJobData.billsLibId;
  1819. let serialNo = cJobData.serialNo;
  1820. let newJobContent, lastOperator = cJobData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  1821. async.parallel([
  1822. function (cb) {
  1823. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  1824. if(err){
  1825. cb(err)
  1826. }
  1827. else {
  1828. let newJobId = result.sequence_value;
  1829. newJobContent = {
  1830. id: newJobId,
  1831. billsLibId: billsLibId,
  1832. code: serialNo,
  1833. content: data,
  1834. deleted: false
  1835. };
  1836. JobContent.create(newJobContent, function(err){
  1837. if(err){
  1838. cb(err);
  1839. }
  1840. else{
  1841. cb(null, newJobId);
  1842. }
  1843. });
  1844. }
  1845. });
  1846. },
  1847. function (cb) {
  1848. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1849. if(err){
  1850. cb(err);
  1851. }
  1852. else{
  1853. if(result.length > 0 ){
  1854. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1855. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1856. if(err){
  1857. cb(err);
  1858. }
  1859. else{
  1860. cb(null);
  1861. }
  1862. });
  1863. }
  1864. }
  1865. });
  1866. }
  1867. ], function (err, result) {
  1868. if(err){
  1869. callback(1, 'Error', null);
  1870. }
  1871. else{
  1872. callback(0, '', result[0])
  1873. }
  1874. })
  1875. };
  1876. billsLibDao.prototype.updateJobContent = function(uJobData, callback){
  1877. let billsLibId = uJobData.billsLibId;
  1878. let field = uJobData.field;
  1879. let updateData = uJobData.data;
  1880. let updateid = uJobData.updateId, lastOperator = uJobData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss'),
  1881. needSet = {};
  1882. needSet[field] = updateData;
  1883. async.parallel([
  1884. function (cb) {
  1885. JobContent.update({billsLibId: billsLibId, id: updateid}, {$set: needSet}, function (err) {
  1886. if(err){
  1887. cb(err);
  1888. }
  1889. else{
  1890. cb(null);
  1891. }
  1892. });
  1893. },
  1894. function (cb) {
  1895. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1896. if(err){
  1897. cb(err);
  1898. }
  1899. else{
  1900. if(result.length > 0 ){
  1901. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1902. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1903. if(err){
  1904. cb(err);
  1905. }
  1906. else{
  1907. cb(null);
  1908. }
  1909. });
  1910. }
  1911. }
  1912. });
  1913. }
  1914. ], function (err) {
  1915. if(err){
  1916. callback(1, 'Error');
  1917. }
  1918. else{
  1919. callback(0, '');
  1920. }
  1921. });
  1922. };
  1923. billsLibDao.prototype.deleteJobContent = function(data, callback){
  1924. let delIds = data.ids;
  1925. let billsLibId = data.billsLibId, lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  1926. if(delIds){
  1927. async.parallel([
  1928. function (cb) {
  1929. async.each(delIds, function(id, ecb){
  1930. JobContent.update({billsLibId: billsLibId, id: id}, {$set: {deleted: true}}, function(err){
  1931. if(err){
  1932. ecb(err);
  1933. }
  1934. else {
  1935. ecb(null);
  1936. }
  1937. });
  1938. }, function(err){
  1939. if(err){
  1940. cb(err);
  1941. }else {
  1942. cb(null);
  1943. }
  1944. });
  1945. },
  1946. function (cb) {
  1947. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  1948. if(err){
  1949. cb(err);
  1950. }
  1951. else{
  1952. if(result.length > 0 ){
  1953. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1954. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1955. if(err){
  1956. cb(err);
  1957. }
  1958. else{
  1959. cb(null);
  1960. }
  1961. });
  1962. }
  1963. }
  1964. });
  1965. }
  1966. ], function (err) {
  1967. if(err){
  1968. callback(1, 'Error');
  1969. }
  1970. else{
  1971. callback(0, '');
  1972. }
  1973. })
  1974. }
  1975. }
  1976. billsLibDao.prototype.pasteJobs = function (data, callback) {
  1977. let pasteDatas = data.pasteDatas;
  1978. let updateDatas = pasteDatas.updateDatas,
  1979. createDatas = pasteDatas.createDatas;
  1980. let functions = [], lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  1981. let parallelFucs = {
  1982. updateLastOpr: function () {
  1983. return function (cb) {
  1984. StdBillsLib.find({billsLibId: data.billsLibId}, function (err, result) {
  1985. if(err){
  1986. cb(err);
  1987. }
  1988. else{
  1989. if(result.length > 0 ){
  1990. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  1991. StdBillsLib.update({billsLibId: data.billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  1992. if(err){
  1993. cb(err);
  1994. }
  1995. else{
  1996. cb(null);
  1997. }
  1998. });
  1999. }
  2000. }
  2001. });
  2002. }
  2003. },
  2004. updateFuc: function(data){
  2005. let updateId = data.orgId,
  2006. field = data.field,
  2007. updateData = data.data, billsLibId = data.billsLibId;
  2008. if(field === 'code'){
  2009. return function (cb){
  2010. JobContent.update({billsLibId: billsLibId, id: updateId}, {$set: {code: updateData}}, function(err){
  2011. if(err){
  2012. cb(err);
  2013. }else {
  2014. cb(null, data);
  2015. }
  2016. });
  2017. };
  2018. }else {
  2019. return function (cb){
  2020. JobContent.update({billsLibId: billsLibId, id: updateId}, {$set: {content: updateData}}, function(err){
  2021. if(err){
  2022. cb(err);
  2023. }else {
  2024. cb(null, data);
  2025. }
  2026. });
  2027. }
  2028. }
  2029. },
  2030. createFuc: function(data){
  2031. let billsLibId = data.billsLibId,
  2032. code;
  2033. let jobObj;
  2034. if(data.type === 'CreateT'){
  2035. jobObj = {
  2036. billsLibId: billsLibId,
  2037. code: data.code,
  2038. content: data.content,
  2039. deleted: false
  2040. }
  2041. }
  2042. else{
  2043. if(data.field === 'code'){
  2044. jobObj = {
  2045. billsLibId: billsLibId,
  2046. code: data.data,
  2047. content: '',
  2048. deleted: false
  2049. }
  2050. }
  2051. else {
  2052. jobObj = {
  2053. billsLibId: billsLibId,
  2054. code: data.code,
  2055. content: data.data,
  2056. deleted: false
  2057. }
  2058. }
  2059. }
  2060. return function (cb){
  2061. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  2062. if(err){
  2063. cb(err);
  2064. }
  2065. else {
  2066. let newJobId = result.sequence_value;
  2067. jobObj.id = newJobId;
  2068. data.newJobId = newJobId
  2069. JobContent.create(jobObj, function(err){
  2070. if(err){
  2071. cb(err);
  2072. }else {
  2073. cb(null, data);
  2074. }
  2075. });
  2076. }
  2077. });
  2078. }
  2079. }
  2080. };
  2081. if(updateDatas.length > 0){
  2082. for(let i=0; i<updateDatas.length; i++){
  2083. functions.push(parallelFucs.updateFuc(updateDatas[i]));
  2084. }
  2085. }
  2086. if(createDatas.length > 0){
  2087. for(let i =0; i<createDatas.length; i++){
  2088. functions.push(parallelFucs.createFuc(createDatas[i]));
  2089. }
  2090. }
  2091. functions.push(parallelFucs.updateLastOpr());
  2092. async.parallel(functions, function(err, datas){
  2093. if(err){
  2094. callback(1, 'Error', null);
  2095. }else {
  2096. callback(0, '', datas);
  2097. }
  2098. });
  2099. };
  2100. billsLibDao.prototype.edCreateJob = function(data, callback){
  2101. let billsLibId = data.billsLibId,
  2102. code = data.code,
  2103. billsId = data.billsId,
  2104. content = data.data,
  2105. serialNo = data.serialNo, lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  2106. async.waterfall([
  2107. function(cb){
  2108. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  2109. if(err){
  2110. cb(err, null);
  2111. }
  2112. else {
  2113. let newJobId = result.sequence_value;
  2114. cb(null, newJobId);
  2115. }
  2116. })
  2117. },
  2118. function(newJobId, cb){
  2119. async.parallel([
  2120. function(pcb){
  2121. JobContent.create({id: newJobId, billsLibId: billsLibId, code: code, content: content, deleted: false}, function(err){
  2122. if(err){
  2123. pcb(err, null);
  2124. }
  2125. else {
  2126. pcb(null, newJobId);
  2127. }
  2128. });
  2129. },
  2130. function(pcb){
  2131. Bills.update({billsLibId: billsLibId, ID: billsId, deleted: false}, {$addToSet: {jobs: {id: newJobId, serialNo: serialNo}}}, function(err){
  2132. if(err){
  2133. pcb(err, null);
  2134. }
  2135. else {
  2136. pcb(null, newJobId);
  2137. }
  2138. });
  2139. },
  2140. function (pcb) {
  2141. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2142. if(err){
  2143. pcb(err);
  2144. }
  2145. else{
  2146. if(result.length > 0 ){
  2147. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2148. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2149. if(err){
  2150. pcb(err);
  2151. }
  2152. else{
  2153. pcb(null);
  2154. }
  2155. });
  2156. }
  2157. }
  2158. });
  2159. }
  2160. ], function(err, result){
  2161. if(err){
  2162. cb(err, null);
  2163. }
  2164. else {
  2165. cb(null, result[0]);
  2166. }
  2167. });
  2168. }
  2169. ], function(err, reslut){
  2170. if(err){
  2171. callback(1, "Error", null);
  2172. }
  2173. else {
  2174. callback(0, '', reslut);
  2175. }
  2176. });
  2177. };
  2178. billsLibDao.prototype.edUpdateJob = function(data, callback){
  2179. let billsLibId = data.billsLibId,
  2180. billsId = data.billsId,
  2181. content = data.content,
  2182. code = data.code,
  2183. orgJobId = data.orgJobId, lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  2184. async.waterfall([
  2185. function(cb){
  2186. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  2187. if(err){
  2188. cb(err, null);
  2189. }
  2190. else {
  2191. let newJobId = result.sequence_value;
  2192. cb(null, newJobId);
  2193. }
  2194. })
  2195. },
  2196. function(newJobId, cb){
  2197. async.parallel([
  2198. function(pcb){
  2199. JobContent.create({id: newJobId, billsLibId: billsLibId, code: code, content: content, deleted: false}, function(err){
  2200. if(err){
  2201. pcb(err, null);
  2202. }
  2203. else {
  2204. pcb(null, newJobId);
  2205. }
  2206. });
  2207. },
  2208. function(pcb){
  2209. Bills.update({billsLibId: billsLibId, ID: billsId, deleted: false, 'jobs.id': orgJobId}, {$set: {'jobs.$.id': newJobId}}, function(err){
  2210. if(err){
  2211. pcb(err, null);
  2212. }
  2213. else {
  2214. pcb(null, newJobId);
  2215. }
  2216. });
  2217. },
  2218. function (pcb) {
  2219. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2220. if(err){
  2221. pcb(err);
  2222. }
  2223. else{
  2224. if(result.length > 0 ){
  2225. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2226. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2227. if(err){
  2228. pcb(err);
  2229. }
  2230. else{
  2231. pcb(null);
  2232. }
  2233. });
  2234. }
  2235. }
  2236. });
  2237. }
  2238. ], function(err, result){
  2239. if(err){
  2240. cb(err, null);
  2241. }
  2242. else {
  2243. cb(null, result[0]);
  2244. }
  2245. });
  2246. }
  2247. ], function(err, reslut){
  2248. if(err){
  2249. callback(1, "Error", null);
  2250. }
  2251. else {
  2252. callback(0, '', reslut);
  2253. }
  2254. });
  2255. };
  2256. //----------------------ItemCharacter---------------------
  2257. billsLibDao.prototype.getItemCharacter = function(gdata, callback){
  2258. let billsLibId = gdata.billsLibId;
  2259. ItemCharacter.find({billsLibId: billsLibId, deleted: false}, '-_id').sort({code: 1}).exec(function(err, result){
  2260. if(err){
  2261. callback(1, 'Error', null);
  2262. }
  2263. else {
  2264. callback(0, '', result);
  2265. }
  2266. });
  2267. }
  2268. billsLibDao.prototype.createItemCharacter = function(cItemData, callback){
  2269. let data = cItemData.data;
  2270. let billsLibId = cItemData.billsLibId;
  2271. let code = cItemData.code;
  2272. let newItemCharacter, lastOperator = cItemData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  2273. async.parallel([
  2274. function (cb) {
  2275. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function (err, result) {
  2276. if(err){
  2277. cb(err);
  2278. }
  2279. else{
  2280. let newItemId = result.sequence_value;
  2281. newItemCharacter = {
  2282. id: newItemId,
  2283. billsLibId: billsLibId,
  2284. content: data,
  2285. code: code,
  2286. deleted: false
  2287. }
  2288. ItemCharacter.create(newItemCharacter, function(err){
  2289. if(err){
  2290. cb(err);
  2291. }
  2292. else{
  2293. cb(null, newItemId);
  2294. }
  2295. });
  2296. }
  2297. });
  2298. },
  2299. function (cb) {
  2300. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2301. if(err){
  2302. cb(err);
  2303. }
  2304. else{
  2305. if(result.length > 0 ){
  2306. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2307. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2308. if(err){
  2309. cb(err);
  2310. }
  2311. else{
  2312. cb(null);
  2313. }
  2314. });
  2315. }
  2316. }
  2317. });
  2318. }
  2319. ], function (err, result) {
  2320. if(err){
  2321. callback(1, 'Error', null);
  2322. }
  2323. else{
  2324. callback(0, '', result[0]);
  2325. }
  2326. });
  2327. };
  2328. billsLibDao.prototype.updateItemCharacter = function(uItemData, callback){
  2329. let field = uItemData.field;
  2330. let updateData = uItemData.data;
  2331. let id = uItemData.updateId;
  2332. let billsLibId = uItemData.billsLibId, needSet = {},
  2333. lastOperator = uItemData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  2334. needSet[field] = updateData;
  2335. async.parallel([
  2336. function (cb) {
  2337. ItemCharacter.update({billsLibId: billsLibId, id: id}, {$set: needSet}, function(err){
  2338. if(err){
  2339. cb(err);
  2340. }
  2341. else{
  2342. cb(null);
  2343. }
  2344. });
  2345. },
  2346. function (cb) {
  2347. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2348. if(err){
  2349. cb(err);
  2350. }
  2351. else{
  2352. if(result.length > 0 ){
  2353. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2354. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2355. if(err){
  2356. cb(err);
  2357. }
  2358. else{
  2359. cb(null);
  2360. }
  2361. });
  2362. }
  2363. }
  2364. });
  2365. }
  2366. ], function (err) {
  2367. if(err){
  2368. callback(1, 'Error');
  2369. }
  2370. else{
  2371. callback(0, '');
  2372. }
  2373. });
  2374. };
  2375. billsLibDao.prototype.updateValue = function(uData, callback){
  2376. let type = uData.type;
  2377. let updateId = uData.updateId;
  2378. let data = uData.data;
  2379. let deleteCodes = uData.deleteCodes;
  2380. let billsLibId = uData.billsLibId, lastOperator = uData.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  2381. if(type === 'create'){
  2382. async.parallel([
  2383. function (cb) {
  2384. ItemCharacter.update({billsLibId: billsLibId, id: updateId}, {$addToSet: {itemValue: data}}, function(err){
  2385. if(err){
  2386. cb(err);
  2387. }
  2388. else{
  2389. cb(null);
  2390. }
  2391. });
  2392. },
  2393. function (cb) {
  2394. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2395. if(err){
  2396. cb(err);
  2397. }
  2398. else{
  2399. if(result.length > 0 ){
  2400. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2401. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2402. if(err){
  2403. cb(err);
  2404. }
  2405. else{
  2406. cb(null);
  2407. }
  2408. });
  2409. }
  2410. }
  2411. });
  2412. }
  2413. ], function (err) {
  2414. if(err){
  2415. callback(1, 'Error');
  2416. }
  2417. else{
  2418. callback(0, '');
  2419. }
  2420. })
  2421. }
  2422. else if(type === 'update'){
  2423. if(data.field === 'code'){
  2424. async.parallel([
  2425. function (cb) {
  2426. ItemCharacter.update({billsLibId: billsLibId, id: updateId, 'itemValue.code': data.code}, {$set: {'itemValue.$.code': data.newData}}, function(err){
  2427. if(err){
  2428. cb(err);
  2429. }
  2430. else{
  2431. cb(null);
  2432. }
  2433. });
  2434. },
  2435. function (cb) {
  2436. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2437. if(err){
  2438. cb(err);
  2439. }
  2440. else{
  2441. if(result.length > 0 ){
  2442. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2443. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2444. if(err){
  2445. cb(err);
  2446. }
  2447. else{
  2448. cb(null);
  2449. }
  2450. });
  2451. }
  2452. }
  2453. });
  2454. }
  2455. ], function (err) {
  2456. if(err){
  2457. callback(1, 'Error');
  2458. }
  2459. else{
  2460. callback(0, '');
  2461. }
  2462. });
  2463. }
  2464. else {
  2465. async.parallel([
  2466. function (cb) {
  2467. ItemCharacter.update({billsLibId: billsLibId, id: updateId, 'itemValue.code': data.code}, {$set: {'itemValue.$.value': data.newData}}, function(err,result){
  2468. if(err){
  2469. cb(err);
  2470. }
  2471. else{
  2472. cb(null);
  2473. }
  2474. });
  2475. },
  2476. function (cb) {
  2477. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2478. if(err){
  2479. cb(err);
  2480. }
  2481. else{
  2482. if(result.length > 0 ){
  2483. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2484. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2485. if(err){
  2486. cb(err);
  2487. }
  2488. else{
  2489. cb(null);
  2490. }
  2491. });
  2492. }
  2493. }
  2494. });
  2495. }
  2496. ], function (err) {
  2497. if(err){
  2498. callback(1, 'Error');
  2499. }
  2500. else{
  2501. callback(0, '');
  2502. }
  2503. })
  2504. }
  2505. }
  2506. //delete
  2507. else {
  2508. if(deleteCodes.length > 0){
  2509. async.parallel([
  2510. function (cb) {
  2511. async.each(deleteCodes, function(code, ecb){
  2512. ItemCharacter.update({billsLibId: billsLibId, id: updateId}, {$pull: {itemValue: {code: code}}}, function(err){
  2513. if(err){
  2514. ecb(err);
  2515. }else {
  2516. ecb(null);
  2517. }
  2518. });
  2519. }, function(err){
  2520. if(err){
  2521. cb(err);
  2522. }else {
  2523. cb(null);
  2524. }
  2525. });
  2526. },
  2527. function (cb) {
  2528. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2529. if(err){
  2530. cb(err);
  2531. }
  2532. else{
  2533. if(result.length > 0 ){
  2534. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2535. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2536. if(err){
  2537. cb(err);
  2538. }
  2539. else{
  2540. cb(null);
  2541. }
  2542. });
  2543. }
  2544. }
  2545. });
  2546. }
  2547. ], function (err) {
  2548. if(err){
  2549. callback(1, 'Error');
  2550. }
  2551. else{
  2552. callback(0, '');
  2553. }
  2554. });
  2555. }
  2556. }
  2557. };
  2558. billsLibDao.prototype.deleteItemCharacter = function(data, callback){
  2559. let delIds = data.ids;
  2560. let billsLibId = data.billsLibId, lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  2561. if(delIds){
  2562. async.parallel([
  2563. function (cb) {
  2564. async.each(delIds, function(id, ecb){
  2565. ItemCharacter.update({billsLibId: billsLibId, id: id}, {$set: {deleted: true}}, function(err){
  2566. if(err){
  2567. ecb(err);
  2568. }else {
  2569. ecb(null);
  2570. }
  2571. }, function(err){
  2572. if(err){
  2573. cb(err);
  2574. }else {
  2575. cb(null);
  2576. }
  2577. });
  2578. });
  2579. },
  2580. function (cb) {
  2581. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2582. if(err){
  2583. cb(err);
  2584. }
  2585. else{
  2586. if(result.length > 0 ){
  2587. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2588. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2589. if(err){
  2590. cb(err);
  2591. }
  2592. else{
  2593. cb(null);
  2594. }
  2595. });
  2596. }
  2597. }
  2598. });
  2599. }
  2600. ], function (err) {
  2601. if(err){
  2602. callback(1, 'Error');
  2603. }
  2604. else{
  2605. callback(0, '');
  2606. }
  2607. });
  2608. }
  2609. };
  2610. billsLibDao.prototype.pasteItems = function (data, callback) {
  2611. let pasteDatas = data.pasteDatas;
  2612. let updateDatas = pasteDatas.updateDatas,
  2613. createDatas = pasteDatas.createDatas;
  2614. let functions = [], lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  2615. let parallelFucs = {
  2616. updateLastOpr: function () {
  2617. return function (cb) {
  2618. StdBillsLib.find({billsLibId: data.billsLibId}, function (err, result) {
  2619. if(err){
  2620. cb(err);
  2621. }
  2622. else{
  2623. if(result.length > 0 ){
  2624. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2625. StdBillsLib.update({billsLibId: data.billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2626. if(err){
  2627. cb(err);
  2628. }
  2629. else{
  2630. cb(null);
  2631. }
  2632. });
  2633. }
  2634. }
  2635. });
  2636. }
  2637. },
  2638. updateFuc: function(data){
  2639. let updateId = data.orgId,
  2640. field = data.field,
  2641. updateData = data.data, billsLibId = data.billsLibId;
  2642. if(field === 'code'){
  2643. return function (cb){
  2644. ItemCharacter.update({billsLibId: billsLibId, id: updateId}, {$set: {code: updateData}}, function(err){
  2645. if(err){
  2646. cb(err);
  2647. }else {
  2648. cb(null, data);
  2649. }
  2650. });
  2651. };
  2652. }
  2653. else{
  2654. return function(cb){
  2655. ItemCharacter.update({billsLibId: billsLibId, id: updateId}, {$set: {content: updateData}}, function(err){
  2656. if(err){
  2657. cb(err);
  2658. }else {
  2659. cb(null, data);
  2660. }
  2661. });
  2662. }
  2663. }
  2664. },
  2665. createFuc: function(data){
  2666. let billsLibId = data.billsLibId,
  2667. code;
  2668. let itemObj;
  2669. if(data.type === 'CreateT'){
  2670. itemObj = {
  2671. billsLibId: billsLibId,
  2672. code: data.code,
  2673. content: data.content,
  2674. deleted: false
  2675. }
  2676. }
  2677. else{
  2678. if(data.field === 'code'){
  2679. itemObj = {
  2680. billsLibId: billsLibId,
  2681. code: data.data,
  2682. content: '',
  2683. deleted: false
  2684. }
  2685. }
  2686. else {
  2687. itemObj = {
  2688. billsLibId: billsLibId,
  2689. code: data.code,
  2690. content: data.data,
  2691. deleted: false
  2692. }
  2693. }
  2694. }
  2695. return function (cb){
  2696. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function(err, result){
  2697. if(err){
  2698. cb(err);
  2699. }
  2700. else{
  2701. let newItemId = result.sequence_value;
  2702. itemObj.id = newItemId;
  2703. data.newItemId = newItemId;
  2704. ItemCharacter.create(itemObj, function(err){
  2705. if(err){
  2706. cb(err);
  2707. }else {
  2708. cb(null, data);
  2709. }
  2710. });
  2711. }
  2712. });
  2713. }
  2714. }
  2715. };
  2716. if(updateDatas.length > 0){
  2717. for(let i=0; i<updateDatas.length; i++){
  2718. functions.push(parallelFucs.updateFuc(updateDatas[i]));
  2719. }
  2720. }
  2721. if(createDatas.length > 0){
  2722. for(let i =0; i<createDatas.length; i++){
  2723. functions.push(parallelFucs.createFuc(createDatas[i]));
  2724. }
  2725. }
  2726. functions.push(parallelFucs.updateLastOpr());
  2727. async.parallel(functions, function(err, datas){
  2728. if(err){
  2729. callback(1, 'Error', null);
  2730. }else {
  2731. callback(0, '', datas);
  2732. }
  2733. });
  2734. };
  2735. billsLibDao.prototype.pasteValues = function(data, callback) {
  2736. let pasteDatas = data.pasteDatas;
  2737. let updateDatas = pasteDatas.updateDatas, createDatas = pasteDatas.createDatas;
  2738. let functions = [], lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  2739. let parallelFucs = {
  2740. updateLastOpr: function () {
  2741. return function (cb) {
  2742. StdBillsLib.find({billsLibId: data.billsLibId}, function (err, result) {
  2743. if(err){
  2744. cb(err);
  2745. }
  2746. else{
  2747. if(result.length > 0 ){
  2748. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2749. StdBillsLib.update({billsLibId: data.billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2750. if(err){
  2751. cb(err);
  2752. }
  2753. else{
  2754. cb(null);
  2755. }
  2756. });
  2757. }
  2758. }
  2759. });
  2760. }
  2761. },
  2762. updateFuc: function(data){
  2763. let billsLibId = data.billsLibId, itemId = data.itemId, orgCode = data.orgId;
  2764. if (data.type === 'UpdateT') {
  2765. let valueObj = {code: data.code, value: data.content};
  2766. return function (cb){
  2767. ItemCharacter.update({billsLibId: billsLibId, id: itemId}, {$pull: {itemValue: {code: orgCode}}}, function (err) {
  2768. if (err) {
  2769. cb(err);
  2770. }
  2771. else {
  2772. ItemCharacter.update({billsLibId: billsLibId, id: itemId}, {$addToSet: {itemValue: valueObj}}, function (err) {
  2773. if (err) {
  2774. cb(err);
  2775. }
  2776. else {
  2777. cb(null, data);
  2778. }
  2779. });
  2780. }
  2781. });
  2782. };
  2783. }
  2784. else if (data.type === 'Update' && data.field === 'code') {
  2785. return function (cb) {
  2786. ItemCharacter.update({billsLibId: billsLibId, id: itemId, 'itemValue.code': orgCode},
  2787. {$set: {'itemValue.$.code': data.data}}, function (err) {
  2788. if(err){
  2789. cb(err);
  2790. }
  2791. else {
  2792. cb(null, data);
  2793. }
  2794. });
  2795. }
  2796. }
  2797. else if(data.type === 'Update' && data.field === 'value') {
  2798. return function (cb){
  2799. ItemCharacter.update({billsLibId: billsLibId, id: itemId, 'itemValue.code': orgCode}, {$set: {'itemValue.$.value': data.data}}, function(err){
  2800. if(err){
  2801. cb(err);
  2802. }
  2803. else {
  2804. cb(null, data);
  2805. }
  2806. });
  2807. };
  2808. }
  2809. },
  2810. createFuc: function(data){
  2811. let valueObj;
  2812. if(data.type === 'CreateT'){
  2813. valueObj = {code: data.code, value: data.content};
  2814. return function (cb){
  2815. ItemCharacter.update({billsLibId: data.billsLibId, id: data.itemId}, {$addToSet: {itemValue: valueObj}}, function (err) {
  2816. if (err) {
  2817. cb(err);
  2818. }
  2819. else {
  2820. cb(null, data);
  2821. }
  2822. });
  2823. };
  2824. }
  2825. else if(data.type === 'Create' && data.field === 'code'){
  2826. valueObj = {code: data.data, value: ''};
  2827. return function (cb){
  2828. ItemCharacter.update({billsLibId: data.billsLibId, id: data.itemId}, {$addToSet: {itemValue: valueObj}}, function (err) {
  2829. if (err) {
  2830. cb(err);
  2831. }
  2832. else {
  2833. cb(null, data);
  2834. }
  2835. });
  2836. };
  2837. }
  2838. else {
  2839. valueObj = {code: data.code, value: data.data};
  2840. return function(cb){
  2841. ItemCharacter.update({billsLibId: data.billsLibId, id: data.itemId}, {$addToSet: {itemValue: valueObj}}, function (err) {
  2842. if (err) {
  2843. cb(err);
  2844. }
  2845. else {
  2846. cb(null, data);
  2847. }
  2848. });
  2849. };
  2850. }
  2851. }
  2852. };
  2853. if (updateDatas.length > 0) {
  2854. for (let i = 0; i < updateDatas.length; i++) {
  2855. functions.push(parallelFucs.updateFuc(updateDatas[i]));
  2856. }
  2857. }
  2858. if(createDatas.length >0){
  2859. for(let i=0; i< createDatas.length; i++){
  2860. functions.push(parallelFucs.createFuc(createDatas[i]));
  2861. }
  2862. }
  2863. functions.push(parallelFucs.updateLastOpr());
  2864. async.parallel(functions, function(err, datas){
  2865. if(err){
  2866. callback(1, 'Error', null);
  2867. }
  2868. else {
  2869. callback(0, '', datas);
  2870. }
  2871. });
  2872. };
  2873. billsLibDao.prototype.edCreateItem = function(data, callback){
  2874. let billsLibId = data.billsLibId,
  2875. code = data.code,
  2876. billsId = data.billsId,
  2877. content = data.data,
  2878. serialNo = data.serialNo, lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  2879. async.waterfall([
  2880. function(cb){
  2881. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function(err, result){
  2882. if(err){
  2883. cb(err, null);
  2884. }
  2885. else {
  2886. let newItemId = result.sequence_value;
  2887. cb(null, newItemId);
  2888. }
  2889. })
  2890. },
  2891. function(newItemId, cb){
  2892. async.parallel([
  2893. function(pcb){
  2894. ItemCharacter.create({id: newItemId, billsLibId: billsLibId, code: code, content: content, deleted: false}, function(err){
  2895. if(err){
  2896. pcb(err, null);
  2897. }
  2898. else {
  2899. pcb(null, newItemId);
  2900. }
  2901. });
  2902. },
  2903. function(pcb){
  2904. Bills.update({billsLibId: billsLibId, ID: billsId, deleted: false}, {$addToSet: {items: {id: newItemId, serialNo: serialNo}}}, function(err){
  2905. if(err){
  2906. pcb(err, null);
  2907. }
  2908. else {
  2909. pcb(null, newItemId);
  2910. }
  2911. });
  2912. },
  2913. function (pcb) {
  2914. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2915. if(err){
  2916. pcb(err);
  2917. }
  2918. else{
  2919. if(result.length > 0 ){
  2920. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2921. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  2922. if(err){
  2923. pcb(err);
  2924. }
  2925. else{
  2926. pcb(null);
  2927. }
  2928. });
  2929. }
  2930. }
  2931. });
  2932. }
  2933. ], function(err, result){
  2934. if(err){
  2935. cb(err, null);
  2936. }
  2937. else {
  2938. cb(null, result[0]);
  2939. }
  2940. });
  2941. }
  2942. ], function(err, reslut){
  2943. if(err){
  2944. callback(1, "Error", null);
  2945. }
  2946. else {
  2947. callback(0, '', reslut);
  2948. }
  2949. });
  2950. };
  2951. billsLibDao.prototype.edUpdateItem = function(data, callback){
  2952. let billsLibId = data.billsLibId,
  2953. billsId = data.billsId,
  2954. content = data.content,
  2955. code = data.code,
  2956. orgItemId = data.orgItemId, lastOperator = data.lastOperator, lastOperateDate = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss');
  2957. async.waterfall([
  2958. function(cb){
  2959. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function(err, result){
  2960. if(err){
  2961. cb(err, null);
  2962. }
  2963. else {
  2964. let newItemId = result.sequence_value;
  2965. cb(null, newItemId);
  2966. }
  2967. })
  2968. },
  2969. function(newItemId, cb){
  2970. async.parallel([
  2971. function(pcb){
  2972. ItemCharacter.create({id: newItemId, billsLibId: billsLibId, code: code, content: content, deleted: false}, function(err){
  2973. if(err){
  2974. pcb(err, null);
  2975. }
  2976. else {
  2977. pcb(null, newItemId);
  2978. }
  2979. });
  2980. },
  2981. function(pcb){
  2982. Bills.update({billsLibId: billsLibId, ID: billsId, deleted: false, 'items.id': orgItemId}, {$set: {'items.$.id': newItemId}}, function(err){
  2983. if(err){
  2984. pcb(err, null);
  2985. }
  2986. else {
  2987. pcb(null, newItemId);
  2988. }
  2989. });
  2990. },
  2991. function (pcb) {
  2992. StdBillsLib.find({billsLibId: billsLibId}, function (err, result) {
  2993. if(err){
  2994. pcb(err);
  2995. }
  2996. else{
  2997. if(result.length > 0 ){
  2998. let newRecentOpr = getNewOprArr(result[0].recentOpr, lastOperator, lastOperateDate);
  2999. StdBillsLib.update({billsLibId: billsLibId}, {$set: {recentOpr: newRecentOpr}}, function(err){
  3000. if(err){
  3001. pcb(err);
  3002. }
  3003. else{
  3004. pcb(null);
  3005. }
  3006. });
  3007. }
  3008. }
  3009. });
  3010. }
  3011. ], function(err, result){
  3012. if(err){
  3013. cb(err, null);
  3014. }
  3015. else {
  3016. cb(null, result[0]);
  3017. }
  3018. });
  3019. }
  3020. ], function(err, reslut){
  3021. if(err){
  3022. callback(1, "Error", null);
  3023. }
  3024. else {
  3025. callback(0, '', reslut);
  3026. }
  3027. });
  3028. };
  3029. //
  3030. module.exports = new billsLibDao();