bills_lib_interfaces.js 70 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989
  1. /**
  2. * Created by vian on 2017/3/20.
  3. */
  4. let model = require("./bills_lib_model");
  5. let counter = require("../../../public/counter/counter");
  6. let async = require("async");
  7. let StdBillsLib = model.stdBillsLibMod;
  8. let Bills = model.billsMod;
  9. let JobContent = model.jobContentMod;
  10. let ItemCharacter = model.itemCharacterMod;
  11. let billsLibDao = function(){};
  12. billsLibDao.prototype.getMaxNumber = function(gData, callback){
  13. let billsLibId = gData.billsLibId;
  14. let field = gData.field;
  15. if(field === 'jobs'){
  16. JobContent.find({billsLibId: billsLibId, deleted: false}).sort({code: -1}).limit(1).exec(function(err, result){
  17. if(err){
  18. callback(1, 'Error', null);
  19. }
  20. else {
  21. callback(0, '', result);
  22. }
  23. });
  24. }
  25. else if(field === 'items'){
  26. ItemCharacter.find({billsLibId: billsLibId, deleted: false}).sort({code: -1}).limit(1).exec(function(err, result){
  27. if(err){
  28. callback(1, 'Error', null);
  29. }
  30. else {
  31. callback(0, '', result);
  32. }
  33. });
  34. }
  35. };
  36. //----------StdBillsLib-------------------
  37. billsLibDao.prototype.getABillsLib = function(data, callback){
  38. let billsLibId = data.billsLibId;
  39. StdBillsLib.find({billsLibId: billsLibId, deleted: false}, function(err, data){
  40. if(err){
  41. callback(1, 'Error', null);
  42. }
  43. else {
  44. callback(0, '', data);
  45. }
  46. });
  47. };
  48. /*billsLibDao.prototype.getStdBillsLib = function(data, callback){
  49. let userId = data.userId;
  50. StdBillsLib.find({userId: userId, deleted: false}, "-_id", function(err, data){
  51. if(err){
  52. callback(1, "Error", null);
  53. }
  54. else{
  55. callback(0, "", data);
  56. }
  57. })
  58. };*/
  59. billsLibDao.prototype.getStdBillsLib = function(data, callback){
  60. let userId = data.userId;
  61. StdBillsLib.find({userId: userId, deleted: false}, "-_id", function(err, data){
  62. if(err){
  63. callback(1, "Error", null);
  64. }
  65. else{
  66. callback(0, "", data);
  67. }
  68. })
  69. };
  70. billsLibDao.prototype.createStdBillsLib = function(clibData, callback){
  71. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib, 1, function(err, result){
  72. let billsLibId = result.value.sequence_value;
  73. let userId = clibData.userId;
  74. let billsLibName = clibData.name;
  75. let createDate = Date.now();
  76. let newStdBillsLib = {
  77. userId: userId,
  78. billsLibId: billsLibId,
  79. billsLibName: billsLibName,
  80. createDate: createDate,
  81. deleted: false
  82. };
  83. StdBillsLib.create(newStdBillsLib, function(err){
  84. if(err){
  85. callback(1, "Error", null);
  86. }
  87. else {
  88. StdBillsLib.find({billsLibId: billsLibId}, function(err, data){
  89. if(err){
  90. callback(1, "Error", null)
  91. }
  92. else {
  93. callback(0, "", data);
  94. }
  95. });
  96. }
  97. });
  98. });
  99. };
  100. billsLibDao.prototype.deleteStdBillsLib = function(billsLibId, callback){
  101. StdBillsLib.update({billsLibId: billsLibId}, {$set: {deleted: true}}, function(err){
  102. if(err){
  103. callback(1, 'Error');
  104. }
  105. else{
  106. callback(0, '');
  107. }
  108. });
  109. };
  110. billsLibDao.prototype.renameStdBillsLib = function(renameData, callback){
  111. let billsLibId = renameData.id;
  112. let renameVal = renameData.value;
  113. StdBillsLib.update({billsLibId: billsLibId}, {$set:{billsLibName: renameVal}}, function(err){
  114. if(err){
  115. callback(1, "Error");
  116. }
  117. else{
  118. callback(0, "");
  119. }
  120. });
  121. };
  122. billsLibDao.prototype.getStdBillsLibName = function(billsLibId, callback){
  123. StdBillsLib.find({billsLibId: billsLibId, deleted: false}, "-_id", function(err, data){
  124. if(err){
  125. callback(1, "Error", null);
  126. }
  127. else {
  128. callback(0, "", data);
  129. }
  130. });
  131. };
  132. billsLibDao.prototype.getCurrentUniqId = function(callback){
  133. counter.counterDAO.getCurrentID(counter.moduleName.billsLib, function(result, err){
  134. let id = result.sequence_value;
  135. if(err){
  136. callback(1, 'Error', null);
  137. }
  138. else{
  139. callback(0, '', id);
  140. }
  141. });
  142. }
  143. //----------------------------Bills---------------------
  144. billsLibDao.prototype.getBills = function (billsLibId, callback) {
  145. Bills.find({billsLibId: billsLibId, deleted: false}, "-_id", function(err, billsData){
  146. if(err){
  147. callback(1, "Error", null);
  148. }
  149. else{
  150. callback(0, "", billsData);
  151. }
  152. });
  153. }
  154. billsLibDao.prototype.createBills = function(cbillsData, callback){
  155. let newId = cbillsData.newId;
  156. let pid = cbillsData.ParentID;
  157. let nid = cbillsData.NextSiblingID;
  158. let billsLibId = cbillsData.billsLibId;
  159. let newBills = {
  160. ID: newId,
  161. ParentID: pid,
  162. NextSiblingID: nid,
  163. billsLibId: billsLibId,
  164. code: '',
  165. name: '',
  166. unit: '',
  167. ruleText: '',
  168. Expression: '',
  169. recharge:'',
  170. deleted: false
  171. };
  172. Bills.create(newBills, function(err){
  173. if(err){
  174. callback(1, "Error");
  175. }
  176. else{
  177. callback(0, "");
  178. }
  179. });
  180. };
  181. //org
  182. /*billsLibDao.prototype.updatePNId= function(upData, callback){
  183. let billsLibId = upData.billsLibId;
  184. let updateDatas = upData.updateData;
  185. let success = true;
  186. if(updateDatas.length > 0){
  187. updateDatas.forEach(function(data){
  188. if(data.ID.length >1){
  189. data.ID.forEach(function(id){
  190. if(data.ParentID && data.NextSiblingID){
  191. Bills.update({billsLibId: billsLibId, ID: id}, {$set: {ParentID: data.ParentID, NextSiblingID: data.NextSiblingID}}, function(err){
  192. if(err){
  193. callback(1, "Error")
  194. success = false;
  195. }
  196. });
  197. }
  198. else if(data.ParentID && !data.NextSiblingID){
  199. Bills.update({billsLibId: billsLibId, ID: id}, {$set: {ParentID: data.ParentID}}, function(err){
  200. if(err){
  201. callback(1, 'Error');
  202. success = false;
  203. }
  204. });
  205. }
  206. else if(!data.ParentID && data.NextSiblingID){
  207. Bills.update({billsLibId: billsLibId, ID: id}, {$set: {NextSiblingID: data.NextSiblingID}}, function(err){
  208. if(err){
  209. callback(1, 'Error');
  210. success = false;
  211. }
  212. });
  213. }
  214. });
  215. }
  216. else {
  217. if(data.ParentID && data.NextSiblingID){
  218. Bills.update({billsLibId: billsLibId, ID: data.ID}, {$set: {ParentID: data.ParentID, NextSiblingID: data.NextSiblingID}}, function(err){
  219. if(err){
  220. callback(1, "Error")
  221. success = false;
  222. }
  223. });
  224. }
  225. else if(data.ParentID && !data.NextSiblingID){
  226. Bills.update({billsLibId: billsLibId, ID: data.ID}, {$set: {ParentID: data.ParentID}}, function(err){
  227. if(err){
  228. callback(1, 'Error');
  229. success = false;
  230. }
  231. });
  232. }
  233. else if(!data.ParentID && data.NextSiblingID){
  234. Bills.update({billsLibId: billsLibId, ID: data.ID}, {$set: {NextSiblingID: data.NextSiblingID}}, function(err){
  235. if(err){
  236. callback(1, 'Error');
  237. success = false;
  238. }
  239. });
  240. }
  241. }
  242. });
  243. }
  244. if(success){
  245. callback(0, '');
  246. }
  247. };*/
  248. billsLibDao.prototype.updatePNId= function(upData, callback){
  249. let billsLibId = upData.billsLibId;
  250. let updateDatas = upData.updateData;
  251. let eachDatas = [];
  252. if(updateDatas.length > 0){
  253. for(let i=0; i< updateDatas.length; i++){
  254. if(updateDatas[i].ID.length > 1){
  255. let ids = updateDatas[i].ID;
  256. for(let j=0; j<ids.length; j++){
  257. let eachObj = {
  258. id: ids[j].ID,
  259. data: updateDatas[i]
  260. }
  261. eachDatas.push(eachObj);
  262. }
  263. }
  264. else {
  265. eachDatas.push({id: updateDatas[i].ID, data: updateDatas[i]});
  266. }
  267. }
  268. async.each(eachDatas, function(eachObj, cb){
  269. let id = eachObj.id, data = eachObj.data;
  270. if(data.ParentID && data.NextSiblingID){
  271. Bills.update({billsLibId: billsLibId, ID: id}, {$set: {ParentID: data.ParentID, NextSiblingID: data.NextSiblingID}}, function(err){
  272. if(err){
  273. cb(err);
  274. }else {
  275. cb(null);
  276. }
  277. });
  278. }
  279. else if(data.ParentID && !data.NextSiblingID){
  280. Bills.update({billsLibId: billsLibId, ID: id}, {$set: {ParentID: data.ParentID}}, function(err){
  281. if(err){
  282. if(err){
  283. cb(err);
  284. }else {
  285. cb(null);
  286. }
  287. }
  288. });
  289. }
  290. else if(!data.ParentID && data.NextSiblingID){
  291. Bills.update({billsLibId: billsLibId, ID: id}, {$set: {NextSiblingID: data.NextSiblingID}}, function(err){
  292. if(err){
  293. cb(err);
  294. }else {
  295. cb(null);
  296. }
  297. });
  298. }
  299. }, function(err){
  300. if(err){
  301. callback(1, 'Error');
  302. }
  303. else {
  304. callback(0, '');
  305. }
  306. });
  307. }
  308. }
  309. billsLibDao.prototype.updateBills = function(ubillsData, callback){
  310. let billsLibId = ubillsData.billsLibId;
  311. let updateId = ubillsData.updateId;
  312. let updateField = ubillsData.field;
  313. let updateData = ubillsData.data;
  314. if(updateField === "code"){
  315. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$set: {code: updateData}}, function(err){
  316. if(err){
  317. callback(1, "Error");
  318. }
  319. else {
  320. callback(0, "");
  321. }
  322. });
  323. }
  324. else if(updateField === "name"){
  325. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$set: {name: updateData}}, function(err){
  326. if(err){
  327. callback(1, "Error");
  328. }
  329. else {
  330. callback(0, "");
  331. }
  332. });
  333. }
  334. else if(updateField === "unit"){
  335. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$set: {unit: updateData}}, function(err){
  336. if(err){
  337. callback(1, "Error");
  338. }
  339. else {
  340. callback(0, "");
  341. }
  342. });
  343. }
  344. else if(updateField === "ruleText"){
  345. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$set: {ruleText: updateData}}, function(err){
  346. if(err){
  347. callback(1, "Error");
  348. }
  349. else {
  350. callback(0, "");
  351. }
  352. });
  353. }
  354. else if(updateField === "jobs"){
  355. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$addToSet: {jobs: updateData}}, function(err){
  356. if(err){
  357. callback(1, "Error");
  358. }
  359. else {
  360. callback(0, "");
  361. }
  362. });
  363. }
  364. else if(updateField === "items"){
  365. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$addToSet: {items: updateData}}, function(err){
  366. if(err){
  367. callback(1, "Error");
  368. }
  369. else {
  370. callback(0, "");
  371. }
  372. });
  373. }
  374. }
  375. //org
  376. /*billsLibDao.prototype.updateBillsArr = function(updateData, callback){
  377. let billsLibId = updateData.billsLibId;
  378. let updateId = updateData.updateId;
  379. let orgId = updateData.orgId;
  380. let newId = updateData.newId;
  381. let classify = updateData.classify;
  382. let type = updateData.type;
  383. let success = true;
  384. if(classify === 'jobs'){
  385. if(orgId && newId && type === 'update'){
  386. Bills.update({billsLibId: billsLibId, ID: updateId, jobs: orgId}, {$set: {'jobs.$': newId}}, function(err){
  387. if(err){
  388. callback(1, 'Error');
  389. }
  390. else {
  391. callback(0, '');
  392. }
  393. });
  394. }
  395. if(orgId && !newId && type === 'delete'){
  396. orgId.forEach(function(oid){
  397. Bills.update({billsLibId: billsLibId, ID: updateId}, {$pull: {jobs: oid}}, function(err){
  398. if(err){
  399. callback(1, 'Error');
  400. }
  401. });
  402. });
  403. }
  404. //todo: test
  405. if(orgId && !newId && type === 'deleteAll'){
  406. updateId.forEach(function(uid){
  407. orgId.forEach(function(oid){
  408. Bills.update({billsLibId: billsLibId, ID: uid}, {$pull: {jobs: oid}}, function(err){
  409. if(err){
  410. callback(1, 'Error');
  411. }
  412. });
  413. });
  414. });
  415. }
  416. }
  417. else if(classify === 'items'){
  418. if(orgId && newId && type === 'update'){
  419. Bills.update({billsLibId: billsLibId, ID: updateId, items: orgId}, {$set: {'items.$': newId}}, function(err){
  420. if(err){
  421. callback(1, 'Error');
  422. }
  423. else {
  424. callback(0, '');
  425. }
  426. });
  427. }
  428. if(orgId && !newId && type === 'delete'){
  429. orgId.forEach(function(oid){
  430. Bills.update({billsLibId: billsLibId, ID: updateId}, {$pull: {items: oid}}, function(err){
  431. if(err){
  432. callback(1, 'Error');
  433. }
  434. });
  435. });
  436. }
  437. if(orgId && !newId && type === 'deleteAll'){
  438. updateId.forEach(function(uid){
  439. orgId.forEach(function(oid){
  440. Bills.update({billsLibId: billsLibId, ID: uid}, {$pull: {items: oid}}, function(err){
  441. if(err){
  442. callback(1, 'Error');
  443. }
  444. });
  445. });
  446. });
  447. }
  448. }
  449. };*/
  450. billsLibDao.prototype.updateBillsArr = function(updateData, callback){
  451. let billsLibId = updateData.billsLibId;
  452. let updateId = updateData.updateId;
  453. let orgId = updateData.orgId;
  454. let newId = updateData.newId;
  455. let classify = updateData.classify;
  456. let type = updateData.type;
  457. let success = true;
  458. if(classify === 'jobs'){
  459. if(orgId && newId && type === 'update'){
  460. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false, jobs: orgId}, {$set: {'jobs.$': newId}}, function(err){
  461. if(err){
  462. callback(1, 'Error');
  463. }
  464. else {
  465. callback(0, '');
  466. }
  467. });
  468. }
  469. if(orgId && !newId && type === 'delete'){
  470. async.each(orgId, function(oid, cb){
  471. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$pull: {jobs: oid}}, function(err){
  472. if(err){
  473. cb(err);
  474. }else {
  475. cb(null);
  476. }
  477. });
  478. }, function(err){
  479. if(err){
  480. callback(1, 'Error');
  481. }
  482. });
  483. }
  484. //todo: test
  485. if(orgId && !newId && type === 'deleteAll'){
  486. let delArr = [];
  487. updateId.forEach(function(uid){
  488. orgId.forEach(function(oid){
  489. delArr.push({updateId: uid, delId: oid});
  490. });
  491. });
  492. async.each(delArr, function(delObj, cb){
  493. Bills.update({billsLibId: billsLibId, ID: delObj.updateId, deleted: false}, {$pull: {jobs: delObj.delId}}, function(err){
  494. if(err){
  495. cb(err);
  496. }else {
  497. cb(null);
  498. }
  499. });
  500. }, function(err){
  501. if(err){
  502. callback(1, 'Error');
  503. }else {
  504. callback(0, '');
  505. }
  506. });
  507. }
  508. }
  509. else if(classify === 'items'){
  510. if(orgId && newId && type === 'update'){
  511. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false, items: orgId}, {$set: {'items.$': newId}}, function(err){
  512. if(err){
  513. callback(1, 'Error');
  514. }
  515. else {
  516. callback(0, '');
  517. }
  518. });
  519. }
  520. if(orgId && !newId && type === 'delete'){
  521. async.each(orgId, function(oid, cb){
  522. Bills.update({billsLibId: billsLibId, ID: updateId, deleted: false}, {$pull: {items: oid}}, function(err){
  523. if(err){
  524. cb(err);
  525. }else {
  526. cb(null);
  527. }
  528. });
  529. }, function(err){
  530. if(err){
  531. callback(1, 'Error');
  532. }else {
  533. callback(0, '');
  534. }
  535. });
  536. }
  537. if(orgId && !newId && type === 'deleteAll'){
  538. let delArr = [];
  539. updateId.forEach(function(uid){
  540. orgId.forEach(function(oid){
  541. delArr.push({updateId: uid, delId: oid});
  542. });
  543. });
  544. async.each(delArr, function(delObj, cb){
  545. Bills.update({billsLibId: billsLibId, ID: delObj.updateId, deleted: false}, {$pull: {items: delObj.delId}}, function(err){
  546. if(err){
  547. cb(err);
  548. }else {
  549. cb(null);
  550. }
  551. });
  552. }, function(err){
  553. if(err){
  554. callback(1, 'Error');
  555. }else {
  556. callback(0, '');
  557. }
  558. });
  559. }
  560. }
  561. };
  562. //org
  563. /*billsLibDao.prototype.pasteBills = function(pData, callback){
  564. let datas = pData.datas;
  565. datas.forEach(function(data){
  566. Bills.update({billsLibId: data.billsLibId, ID: data.ID}, {$set: {code: data.code, name: data.name, unit: data.unit, ruleText: data.ruleText}}, function(err){
  567. if(err){
  568. callback(1, 'Error');
  569. }
  570. });
  571. });
  572. }*/
  573. billsLibDao.prototype.pasteBills = function(pData, callback){
  574. let datas = pData.datas;
  575. async.each(datas, function(data, cb){
  576. Bills.update({billsLibId: data.billsLibId, ID: data.ID, deleted: false}, {$set: {code: data.code, name: data.name, unit: data.unit, ruleText: data.ruleText}}, function(err){
  577. if(err){
  578. cb(err);
  579. }else {
  580. cb(null);
  581. }
  582. });
  583. }, function(err){
  584. if(err){
  585. callback(1, 'Error');
  586. }else {
  587. callback(0, '');
  588. }
  589. });
  590. }
  591. //org
  592. /*billsLibDao.prototype.updateRecharge = function(uData, callback){
  593. let billsLibId = uData.billsLibId;
  594. let updateIds = uData.updateIds;
  595. let data = uData.data;
  596. let success = true;
  597. updateIds.forEach(function(id){
  598. Bills.update({billsLibId: billsLibId, ID: id}, {$set: {recharge: data}}, function(err){
  599. if(err){
  600. callback(1, 'Error');
  601. success = false;
  602. }
  603. });
  604. });
  605. if(success){
  606. callback(0, '');
  607. }
  608. };*/
  609. billsLibDao.prototype.updateRecharge = function(uData, callback){
  610. let billsLibId = uData.billsLibId;
  611. let updateIds = uData.updateIds;
  612. let data = uData.data;
  613. async.each(updateIds, function(id, cb){
  614. Bills.update({billsLibId: billsLibId, ID: id, deleted: false}, {$set: {recharge: data}}, function(err){
  615. if(err){
  616. cb(err);
  617. }else {
  618. cb(null);
  619. }
  620. });
  621. }, function(err){
  622. if(err){
  623. callback(1, 'Error');
  624. }else {
  625. callback(0, '');
  626. }
  627. });
  628. };
  629. //org
  630. /*billsLibDao.prototype.pasteRel = function (data, callback) {
  631. const UpdateExist = 'updateExist', UpdateNew = 'updateNew', CreateExist = 'createExist', CreateNew = 'createNew';
  632. const Jobs = 'jobs', Items = 'items';
  633. let success = true;
  634. let field = data.field;
  635. let updateDatas = data.updateDatas;
  636. let createDatas = data.createDatas;
  637. if(field === Jobs){
  638. if(updateDatas.length > 0){
  639. for(let i=0; i<updateDatas.length; i++){
  640. if(updateDatas[i].type === UpdateExist){
  641. let orgJobId = updateDatas[i].orgJobId, newJobId = updateDatas[i].newJobId,
  642. nodeId = updateDatas[i].nodeId, billsLibId = updateDatas[i].billsLibId, newData = updateDatas[i].newData;
  643. if(orgJobId && newJobId && nodeId && billsLibId){
  644. Bills.update({billsLibId: billsLibId, ID: nodeId, jobs: orgJobId}, {$set: {'jobs.$': newJobId}}, function(err){
  645. if(err){
  646. success = false;
  647. }
  648. else{
  649. }
  650. });
  651. }
  652. }
  653. if(updateDatas[i].type === UpdateNew){
  654. let billsLibId = updateDatas[i].billsLibId, nodeId = updateDatas[i].nodeId, newData = updateDatas[i].newData,
  655. orgJobId = updateDatas[i].orgJobId, code = updateDatas[i].code, id = updateDatas[i].newJobId;
  656. if(billsLibId && nodeId && newData && orgJobId && code && id){
  657. let newJobContent;
  658. newJobContent = {
  659. id: id,
  660. billsLibId: billsLibId,
  661. code: code,
  662. content: newData,
  663. deleted: false
  664. }
  665. JobContent.create(newJobContent, function(err){
  666. if(err){
  667. success = false;
  668. }
  669. else{
  670. Bills.update({billsLibId: billsLibId, ID: nodeId, jobs: orgJobId}, {$set: {'jobs.$': id}}, function(err){
  671. if(err){
  672. success = false;
  673. }
  674. else{
  675. }
  676. });
  677. }
  678. });
  679. }
  680. }
  681. }
  682. }
  683. if(createDatas.length > 0){
  684. for(let i=0; i<createDatas.length; i++){
  685. if(createDatas[i].type === CreateExist){
  686. let billsLibId = createDatas[i].billsLibId, newData = createDatas[i].newData,
  687. nodeId = createDatas[i].nodeId, jobId = createDatas[i].jobId;
  688. if(billsLibId && newData && nodeId && jobId){
  689. Bills.update({billsLibId: billsLibId, ID: nodeId}, {$addToSet: {jobs: jobId}}, function(err){
  690. if(err){
  691. success = false;
  692. }
  693. else {
  694. }
  695. });
  696. }
  697. }
  698. if(createDatas[i].type === CreateNew){
  699. let billsLibId = createDatas[i].billsLibId, newData = createDatas[i].newData,
  700. code = createDatas[i].code, nodeId = createDatas[i].nodeId, id = createDatas[i].id;
  701. if(billsLibId && newData && code && id){
  702. let newJobContent;
  703. newJobContent = {
  704. id: id,
  705. billsLibId: billsLibId,
  706. code: code,
  707. content: newData,
  708. deleted: false
  709. }
  710. JobContent.create(newJobContent, function(err){
  711. if(err){
  712. success = false;
  713. }
  714. else{
  715. Bills.update({billsLibId: billsLibId, ID: nodeId}, {$addToSet: {jobs: id}}, function(err){
  716. if(err){
  717. success = false;
  718. }
  719. else {
  720. }
  721. });
  722. }
  723. });
  724. }
  725. }
  726. }
  727. }
  728. }
  729. if(field === Items){
  730. if(updateDatas.length > 0){
  731. for(let i=0; i<updateDatas.length; i++){
  732. if(updateDatas[i].type === UpdateExist){
  733. let orgItemId = updateDatas[i].orgItemId, newItemId = updateDatas[i].newItemId,
  734. nodeId = updateDatas[i].nodeId, billsLibId = updateDatas[i].billsLibId, newData = updateDatas[i].newData;
  735. if(orgItemId && newItemId && nodeId && billsLibId){
  736. Bills.update({billsLibId: billsLibId, ID: nodeId, items: orgItemId}, {$set: {'items.$': newItemId}}, function(err){
  737. if(err){
  738. success = false;
  739. }
  740. else{
  741. }
  742. });
  743. }
  744. }
  745. if(updateDatas[i].type === UpdateNew){
  746. let billsLibId = updateDatas[i].billsLibId, nodeId = updateDatas[i].nodeId, newData = updateDatas[i].newData,
  747. orgItemId = updateDatas[i].orgItemId, code = updateDatas[i].code, id = updateDatas[i].newItemId;
  748. if(billsLibId && nodeId && newData && orgItemId && code && id){
  749. let newItemContent;
  750. newItemContent = {
  751. id: id,
  752. billsLibId: billsLibId,
  753. code: code,
  754. content: newData,
  755. deleted: false
  756. }
  757. ItemCharacter.create(newItemContent, function(err){
  758. if(err){
  759. success = false;
  760. }
  761. else{
  762. Bills.update({billsLibId: billsLibId, ID: nodeId, items: orgItemId}, {$set: {'items.$': id}}, function(err){
  763. if(err){
  764. success = false;
  765. }
  766. else{
  767. }
  768. });
  769. }
  770. });
  771. }
  772. }
  773. }
  774. }
  775. if(createDatas.length > 0){
  776. for(let i=0; i<createDatas.length; i++){
  777. if(createDatas[i].type === CreateExist){
  778. let billsLibId = createDatas[i].billsLibId, newData = createDatas[i].newData,
  779. nodeId = createDatas[i].nodeId, itemId = createDatas[i].itemId;
  780. if(billsLibId && newData && nodeId && itemId){
  781. Bills.update({billsLibId: billsLibId, ID: nodeId}, {$addToSet: {items: itemId}}, function(err){
  782. if(err){
  783. success = false;
  784. }
  785. else {
  786. }
  787. });
  788. }
  789. }
  790. if(createDatas[i].type === CreateNew){
  791. let billsLibId = createDatas[i].billsLibId, newData = createDatas[i].newData,
  792. code = createDatas[i].code, nodeId = createDatas[i].nodeId, id = createDatas[i].id;
  793. if(billsLibId && newData && code && id){
  794. let newItemContent;
  795. newItemContent = {
  796. id: id,
  797. billsLibId: billsLibId,
  798. code: code,
  799. content: newData,
  800. deleted: false
  801. }
  802. ItemCharacter.create(newItemContent, function(err){
  803. if(err){
  804. success = false;
  805. }
  806. else{
  807. Bills.update({billsLibId: billsLibId, ID: nodeId}, {$addToSet: {items: id}}, function(err){
  808. if(err){
  809. success = false;
  810. }
  811. else {
  812. }
  813. });
  814. }
  815. });
  816. }
  817. }
  818. }
  819. }
  820. }
  821. callback(0, '');
  822. };*/
  823. billsLibDao.prototype.pasteRel = function (data, callback) {
  824. const UpdateExist = 'updateExist', UpdateNew = 'updateNew', CreateExist = 'createExist', CreateNew = 'createNew';
  825. const Jobs = 'jobs', Items = 'items';
  826. let success = true;
  827. let field = data.field;
  828. let updateDatas = data.updateDatas;
  829. let createDatas = data.createDatas;
  830. let functions = [];
  831. let parallelFucs = {
  832. updateExJobs: function(data){
  833. let orgJobId = data.orgJobId, newJobId = data.newJobId,
  834. nodeId = data.nodeId, billsLibId = data.billsLibId;
  835. return function (cb){
  836. if(orgJobId && newJobId && nodeId && billsLibId){
  837. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false, jobs: orgJobId}, {$set: {'jobs.$': newJobId}}, function(err){
  838. if(err){
  839. cb(err);
  840. }
  841. else{
  842. cb(null, data)
  843. }
  844. });
  845. }
  846. }
  847. },
  848. updateNeJobs: function(data){
  849. let billsLibId = data.billsLibId, nodeId = data.nodeId, newData = data.newData,
  850. orgJobId = data.orgJobId, code = data.code;
  851. return function (cb){
  852. if(billsLibId && nodeId && newData && orgJobId && code){
  853. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  854. if(err){
  855. cb(err);
  856. }
  857. else {
  858. let newJobId = result.value.sequence_value;
  859. let newJobContent = {
  860. id: newJobId,
  861. billsLibId: billsLibId,
  862. code: code,
  863. content: newData,
  864. deleted: false
  865. };
  866. JobContent.create(newJobContent, function(err){
  867. if(err){
  868. cb(err);
  869. }
  870. else{
  871. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false, jobs: orgJobId}, {$set: {'jobs.$': newJobId}}, function(err){
  872. if(err){
  873. cb(err);
  874. }
  875. else{
  876. data.newJobId = newJobId;
  877. cb(null, data);
  878. }
  879. });
  880. }
  881. });
  882. }
  883. });
  884. }
  885. }
  886. },
  887. createExJobs: function(data){
  888. let billsLibId = data.billsLibId, newData = data.newData,
  889. nodeId = data.nodeId, jobId = data.jobId;
  890. return function (cb){
  891. if(billsLibId && newData && nodeId && jobId){
  892. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false}, {$addToSet: {jobs: jobId}}, function(err){
  893. if(err){
  894. cb(err);
  895. }
  896. else {
  897. cb(null, data);
  898. }
  899. });
  900. }
  901. }
  902. },
  903. createNeJobs: function(data){
  904. let billsLibId = data.billsLibId, newData = data.newData,
  905. code = data.code, nodeId = data.nodeId;
  906. return function (cb){
  907. if(billsLibId && newData && code){
  908. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  909. if(err){
  910. cb(err);
  911. }
  912. else {
  913. let newJobId = result.value.sequence_value;
  914. let newJobContent = {
  915. id: newJobId,
  916. billsLibId: billsLibId,
  917. code: code,
  918. content: newData,
  919. deleted: false
  920. };
  921. JobContent.create(newJobContent, function(err){
  922. if(err){
  923. cb(err);
  924. }
  925. else{
  926. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false}, {$addToSet: {jobs: newJobId}}, function(err){
  927. if(err){
  928. cb(err);
  929. }
  930. else {
  931. data.newJobId = newJobId;
  932. cb(null, data);
  933. }
  934. });
  935. }
  936. });
  937. }
  938. });
  939. }
  940. }
  941. },
  942. updateExItems: function(data){
  943. let orgItemId = data.orgItemId, newItemId = data.newItemId,
  944. nodeId = data.nodeId, billsLibId = data.billsLibId, newData = data.newData;
  945. return function (cb){
  946. if(orgItemId && newItemId && nodeId && billsLibId){
  947. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false, items: orgItemId}, {$set: {'items.$': newItemId}}, function(err){
  948. if(err){
  949. cb(err);
  950. }
  951. else{
  952. cb(null, data);
  953. }
  954. });
  955. }
  956. }
  957. },
  958. updateNeItems: function(data){
  959. let billsLibId = data.billsLibId, nodeId = data.nodeId, newData = data.newData,
  960. orgItemId = data.orgItemId, code = data.code;
  961. return function (cb){
  962. if(billsLibId && nodeId && newData && orgItemId && code){
  963. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function(err, result){
  964. if(err){
  965. cb(err);
  966. }
  967. else {
  968. let newItemId = result.value.sequence_value;
  969. let newItemContent = {
  970. id: newItemId,
  971. billsLibId: billsLibId,
  972. code: code,
  973. content: newData,
  974. deleted: false
  975. };
  976. ItemCharacter.create(newItemId, function(err){
  977. if(err){
  978. cb(err);
  979. }
  980. else{
  981. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false, items: orgItemId}, {$set: {'items.$': newItemId}}, function(err){
  982. if(err){
  983. cb(err);
  984. }
  985. else{
  986. data.newItemId = newItemId;
  987. cb(null, data);
  988. }
  989. });
  990. }
  991. });
  992. }
  993. });
  994. }
  995. }
  996. },
  997. createExItems: function(data){
  998. let billsLibId = data.billsLibId, newData = data.newData,
  999. nodeId = data.nodeId, itemId = data.itemId;
  1000. return function (cb){
  1001. if(billsLibId && newData && nodeId && itemId){
  1002. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false}, {$addToSet: {items: itemId}}, function(err){
  1003. if(err){
  1004. cb(err);
  1005. }
  1006. else {
  1007. cb(null, data);
  1008. }
  1009. });
  1010. }
  1011. }
  1012. },
  1013. createNeItems: function(data){
  1014. let billsLibId = data.billsLibId, newData = data.newData,
  1015. code = data.code, nodeId = data.nodeId, id = data.id;
  1016. return function (cb){
  1017. if(billsLibId && newData && code && id){
  1018. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function(err, result){
  1019. if(err){
  1020. cb(err);
  1021. }
  1022. else {
  1023. let newItemId = result.value.sequence_value;
  1024. let newItemContent = {
  1025. id: newItemId,
  1026. billsLibId: billsLibId,
  1027. code: code,
  1028. content: newData,
  1029. deleted: false
  1030. };
  1031. ItemCharacter.create(newItemContent, function(err){
  1032. if(err){
  1033. cb(err);
  1034. }
  1035. else{
  1036. Bills.update({billsLibId: billsLibId, ID: nodeId, deleted: false}, {$addToSet: {items: newItemId}}, function(err){
  1037. if(err){
  1038. cb(err);
  1039. }
  1040. else {
  1041. data.newItemId = newItemId;
  1042. cb(null, data);
  1043. }
  1044. });
  1045. }
  1046. });
  1047. }
  1048. });
  1049. }
  1050. }
  1051. }
  1052. };
  1053. if(field === Jobs){
  1054. if(updateDatas.length > 0){
  1055. for(let i=0; i<updateDatas.length; i++){
  1056. if(updateDatas[i].type === UpdateExist){
  1057. functions.push(parallelFucs.updateExJobs(updateDatas[i]));
  1058. }
  1059. if(updateDatas[i].type === UpdateNew){
  1060. functions.push(parallelFucs.updateNeJobs(updateDatas[i]));
  1061. }
  1062. }
  1063. }
  1064. if(createDatas.length > 0){
  1065. for(let i=0; i<createDatas.length; i++){
  1066. if(createDatas[i].type === CreateExist){
  1067. functions.push(parallelFucs.createExJobs(createDatas[i]));
  1068. }
  1069. if(createDatas[i].type === CreateNew){
  1070. functions.push(parallelFucs.createNeJobs(createDatas[i]));
  1071. }
  1072. }
  1073. }
  1074. }
  1075. if(field === Items){
  1076. if(updateDatas.length > 0){
  1077. for(let i=0; i<updateDatas.length; i++){
  1078. if(updateDatas[i].type === UpdateExist){
  1079. functions.push(parallelFucs.updateExItems(updateDatas[i]));
  1080. }
  1081. if(updateDatas[i].type === UpdateNew){
  1082. functions.push(parallelFucs.updateNeItems(updateDatas[i]));
  1083. }
  1084. }
  1085. }
  1086. if(createDatas.length > 0){
  1087. for(let i=0; i<createDatas.length; i++){
  1088. if(createDatas[i].type === CreateExist){
  1089. functions.push(parallelFucs.createExItems(createDatas[i]));
  1090. }
  1091. if(createDatas[i].type === CreateNew){
  1092. functions.push(parallelFucs.createNeItems(createDatas[i]));
  1093. }
  1094. }
  1095. }
  1096. }
  1097. async.parallel(functions, function(err, datas){
  1098. if(err){
  1099. callback(1, 'Error', null);
  1100. }else {
  1101. callback(0, '', datas);
  1102. }
  1103. });
  1104. };
  1105. //org
  1106. /*billsLibDao.prototype.deleteBills = function(delData, callback){
  1107. let deleteIds = delData.deleteIds;
  1108. let billsLibId = delData.billsLibId;
  1109. let success = true;
  1110. if(deleteIds){
  1111. deleteIds.forEach(function(delId){
  1112. Bills.update({billsLibId: billsLibId, ID: delId}, {$set: {deleted: true}}, function(err){
  1113. if(err){
  1114. success = false;
  1115. callback(1, 'Error');
  1116. }
  1117. });
  1118. });
  1119. if(success){
  1120. callback(0, '');
  1121. }
  1122. }
  1123. }*/
  1124. billsLibDao.prototype.deleteBills = function(delData, callback){
  1125. let deleteIds = delData.deleteIds;
  1126. let billsLibId = delData.billsLibId;
  1127. if(deleteIds){
  1128. async.each(deleteIds, function(delId, cb){
  1129. Bills.update({billsLibId: billsLibId, ID: delId, deleted: false}, {$set: {deleted: true}}, function(err){
  1130. if(err){
  1131. cb(err);
  1132. }
  1133. });
  1134. }, function(err){
  1135. if(err){
  1136. callback(1, 'Error');
  1137. }
  1138. else {
  1139. callback(0, '');
  1140. }
  1141. });
  1142. }
  1143. }
  1144. //--------------JobContent------------------
  1145. billsLibDao.prototype.getJobContent = function(gJobData, callback){
  1146. let billsLibId = gJobData.billsLibId;
  1147. JobContent.find({billsLibId: billsLibId, deleted: false}, '-_id').sort({code: 1}).exec(function(err, result){
  1148. if(err){
  1149. callback(1, 'Error', null);
  1150. }
  1151. else {
  1152. callback(0, '', result);
  1153. }
  1154. });
  1155. }
  1156. billsLibDao.prototype.createJobContent = function(cJobData, callback){
  1157. let data = cJobData.data;
  1158. let billsLibId = cJobData.billsLibId;
  1159. let serialNo = cJobData.serialNo;
  1160. let newJobContent;
  1161. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  1162. if(err){
  1163. callback(1, 'Error', null)
  1164. }
  1165. else {
  1166. let newJobId = result.value.sequence_value;
  1167. newJobContent = {
  1168. id: newJobId,
  1169. billsLibId: billsLibId,
  1170. code: serialNo,
  1171. content: data,
  1172. deleted: false
  1173. }
  1174. JobContent.create(newJobContent, function(err){
  1175. if(err){
  1176. callback(1, "Error", null);
  1177. }
  1178. else{
  1179. callback(0, "", newJobId);
  1180. }
  1181. });
  1182. }
  1183. });
  1184. };
  1185. billsLibDao.prototype.updateJobContent = function(uJobData, callback){
  1186. let billsLibId = uJobData.billsLibId;
  1187. let field = uJobData.field;
  1188. let updateData = uJobData.data;
  1189. let updateid = uJobData.updateId;
  1190. if(field == "code"){
  1191. JobContent.update({billsLibId: billsLibId, id: updateid}, {$set: {code: updateData}}, function(err){
  1192. if(err){
  1193. callback(1, "Error");
  1194. }
  1195. else{
  1196. callback(0, "");
  1197. }
  1198. });
  1199. }
  1200. else if(field == "content"){
  1201. JobContent.update({billsLibId: billsLibId, id: updateid}, {$set: {content: updateData}}, function(err){
  1202. if(err){
  1203. callback(1, "Error");
  1204. }
  1205. else{
  1206. callback(0, "");
  1207. }
  1208. });
  1209. }
  1210. };
  1211. //org
  1212. /*billsLibDao.prototype.deleteJobContent = function(data, callback){
  1213. let delIds = data.ids;
  1214. let billsLibId = data.billsLibId;
  1215. let success = true;
  1216. delIds.forEach(function(id){
  1217. JobContent.update({billsLibId: billsLibId, id: id}, {$set: {deleted: true}}, function(err,result){
  1218. if(err){
  1219. success = false;
  1220. callback(1, 'Error');
  1221. }
  1222. else {
  1223. }
  1224. });
  1225. });
  1226. }*/
  1227. billsLibDao.prototype.deleteJobContent = function(data, callback){
  1228. let delIds = data.ids;
  1229. let billsLibId = data.billsLibId;
  1230. if(delIds){
  1231. async.each(delIds, function(id, cb){
  1232. JobContent.update({billsLibId: billsLibId, id: id}, {$set: {deleted: true}}, function(err){
  1233. if(err){
  1234. cb(err);
  1235. }
  1236. else {
  1237. cb(null);
  1238. }
  1239. });
  1240. }, function(err){
  1241. if(err){
  1242. callback(1, 'Error');
  1243. }else {
  1244. callback(0, '');
  1245. }
  1246. });
  1247. }
  1248. }
  1249. billsLibDao.prototype.pasteJobs = function (data, callback) {
  1250. let pasteDatas = data.pasteDatas;
  1251. let updateDatas = pasteDatas.updateDatas,
  1252. createDatas = pasteDatas.createDatas;
  1253. let functions = [];
  1254. let parallelFucs = {
  1255. updateFuc: function(data){
  1256. let updateId = data.orgId,
  1257. field = data.field,
  1258. updateData = data.data, billsLibId = data.billsLibId;
  1259. if(field === 'code'){
  1260. return function (cb){
  1261. JobContent.update({billsLibId: billsLibId, id: updateId}, {$set: {code: updateData}}, function(err){
  1262. if(err){
  1263. cb(err);
  1264. }else {
  1265. cb(null, data);
  1266. }
  1267. });
  1268. };
  1269. }else {
  1270. return function (cb){
  1271. JobContent.update({billsLibId: billsLibId, id: updateId}, {$set: {content: updateData}}, function(err){
  1272. if(err){
  1273. cb(err);
  1274. }else {
  1275. cb(null, data);
  1276. }
  1277. });
  1278. }
  1279. }
  1280. },
  1281. createFuc: function(data){
  1282. let billsLibId = data.billsLibId,
  1283. code;
  1284. let jobObj;
  1285. if(data.type === 'CreateT'){
  1286. jobObj = {
  1287. billsLibId: billsLibId,
  1288. code: data.code,
  1289. content: data.content,
  1290. deleted: false
  1291. }
  1292. }
  1293. else{
  1294. if(data.field === 'code'){
  1295. jobObj = {
  1296. billsLibId: billsLibId,
  1297. code: data.data,
  1298. content: '',
  1299. deleted: false
  1300. }
  1301. }
  1302. else {
  1303. jobObj = {
  1304. billsLibId: billsLibId,
  1305. code: data.code,
  1306. content: data.data,
  1307. deleted: false
  1308. }
  1309. }
  1310. }
  1311. return function (cb){
  1312. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  1313. if(err){
  1314. cb(err);
  1315. }
  1316. else {
  1317. let newJobId = result.value.sequence_value;
  1318. jobObj.id = newJobId;
  1319. data.newJobId = newJobId
  1320. JobContent.create(jobObj, function(err){
  1321. if(err){
  1322. cb(err);
  1323. }else {
  1324. cb(null, data);
  1325. }
  1326. });
  1327. }
  1328. });
  1329. }
  1330. }
  1331. };
  1332. if(updateDatas.length > 0){
  1333. for(let i=0; i<updateDatas.length; i++){
  1334. functions.push(parallelFucs.updateFuc(updateDatas[i]));
  1335. }
  1336. }
  1337. if(createDatas.length > 0){
  1338. for(let i =0; i<createDatas.length; i++){
  1339. functions.push(parallelFucs.createFuc(createDatas[i]));
  1340. }
  1341. }
  1342. async.parallel(functions, function(err, datas){
  1343. if(err){
  1344. callback(1, 'Error', null);
  1345. }else {
  1346. callback(0, '', datas);
  1347. }
  1348. });
  1349. };
  1350. billsLibDao.prototype.edCreateJob = function(data, callback){
  1351. let billsLibId = data.billsLibId,
  1352. code = data.code,
  1353. billsId = data.billsId,
  1354. content = data.data;
  1355. async.waterfall([
  1356. function(cb){
  1357. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  1358. if(err){
  1359. cb(err, null);
  1360. }
  1361. else {
  1362. let newJobId = result.value.sequence_value;
  1363. cb(null, newJobId);
  1364. }
  1365. })
  1366. },
  1367. function(newJobId, cb){
  1368. async.parallel([
  1369. function(pcb){
  1370. JobContent.create({id: newJobId, billsLibId: billsLibId, code: code, content: content, deleted: false}, function(err){
  1371. if(err){
  1372. pcb(err, null);
  1373. }
  1374. else {
  1375. pcb(null, newJobId);
  1376. }
  1377. });
  1378. },
  1379. function(pcb){
  1380. Bills.update({billsLibId: billsLibId, ID: billsId, deleted: false}, {$addToSet: {jobs: newJobId}}, function(err){
  1381. if(err){
  1382. pcb(err, null);
  1383. }
  1384. else {
  1385. pcb(null, newJobId);
  1386. }
  1387. });
  1388. }
  1389. ], function(err, result){
  1390. if(err){
  1391. cb(err, null);
  1392. }
  1393. else {
  1394. cb(null, result[0]);
  1395. }
  1396. });
  1397. }
  1398. ], function(err, reslut){
  1399. if(err){
  1400. callback(1, "Error", null);
  1401. }
  1402. else {
  1403. callback(0, '', reslut);
  1404. }
  1405. });
  1406. };
  1407. billsLibDao.prototype.edUpdateJob = function(data, callback){
  1408. let billsLibId = data.billsLibId,
  1409. billsId = data.billsId,
  1410. content = data.content,
  1411. code = data.code,
  1412. orgJobId = data.orgJobId;
  1413. async.waterfall([
  1414. function(cb){
  1415. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_jobs, 1, function(err, result){
  1416. if(err){
  1417. cb(err, null);
  1418. }
  1419. else {
  1420. let newJobId = result.value.sequence_value;
  1421. cb(null, newJobId);
  1422. }
  1423. })
  1424. },
  1425. function(newJobId, cb){
  1426. async.parallel([
  1427. function(pcb){
  1428. JobContent.create({id: newJobId, billsLibId: billsLibId, code: code, content: content, deleted: false}, function(err){
  1429. if(err){
  1430. pcb(err, null);
  1431. }
  1432. else {
  1433. pcb(null, newJobId);
  1434. }
  1435. });
  1436. },
  1437. function(pcb){
  1438. Bills.update({billsLibId: billsLibId, ID: billsId, deleted: false, jobs: orgJobId}, {$set: {'jobs.$': newJobId}}, function(err){
  1439. if(err){
  1440. pcb(err, null);
  1441. }
  1442. else {
  1443. pcb(null, newJobId);
  1444. }
  1445. });
  1446. }
  1447. ], function(err, result){
  1448. if(err){
  1449. cb(err, null);
  1450. }
  1451. else {
  1452. cb(null, result[0]);
  1453. }
  1454. });
  1455. }
  1456. ], function(err, reslut){
  1457. if(err){
  1458. callback(1, "Error", null);
  1459. }
  1460. else {
  1461. callback(0, '', reslut);
  1462. }
  1463. });
  1464. };
  1465. //----------------------ItemCharacter---------------------
  1466. billsLibDao.prototype.getItemCharacter = function(gdata, callback){
  1467. let billsLibId = gdata.billsLibId;
  1468. ItemCharacter.find({billsLibId: billsLibId, deleted: false}, '-_id').sort({code: 1}).exec(function(err, result){
  1469. if(err){
  1470. callback(1, 'Error', null);
  1471. }
  1472. else {
  1473. callback(0, '', result);
  1474. }
  1475. });
  1476. }
  1477. billsLibDao.prototype.createItemCharacter = function(cItemData, callback){
  1478. let data = cItemData.data;
  1479. let billsLibId = cItemData.billsLibId;
  1480. let serialNo = cItemData.serialNo;
  1481. let newItemCharacter;
  1482. let id = cItemData.id;
  1483. newItemCharacter = {
  1484. id: id,
  1485. billsLibId: billsLibId,
  1486. content: data,
  1487. code: serialNo,
  1488. deleted: false
  1489. }
  1490. ItemCharacter.create(newItemCharacter, function(err){
  1491. if(err){
  1492. callback(1, "Error", null);
  1493. }
  1494. else{
  1495. callback(0, "", id);
  1496. }
  1497. });
  1498. };
  1499. billsLibDao.prototype.updateItemCharacter = function(uItemData, callback){
  1500. let field = uItemData.field;
  1501. let updateData = uItemData.data;
  1502. let id = uItemData.updateId;
  1503. let billsLibId = uItemData.billsLibId;
  1504. if(field === "code"){
  1505. ItemCharacter.update({billsLibId: billsLibId, id: id}, {$set: {code: updateData}}, function(err){
  1506. if(err){
  1507. callback(1, "Error");
  1508. }
  1509. else{
  1510. callback(0, "");
  1511. }
  1512. });
  1513. }
  1514. else if(field === "content"){
  1515. ItemCharacter.update({billsLibId: billsLibId, id: id}, {$set: {content: updateData}}, function(err){
  1516. if(err){
  1517. callback(1, "Error");
  1518. }
  1519. else{
  1520. callback(0, "");
  1521. }
  1522. });
  1523. }
  1524. };
  1525. billsLibDao.prototype.updateValue = function(uData, callback){
  1526. let type = uData.type;
  1527. let updateId = uData.updateId;
  1528. let data = uData.data;
  1529. let deleteCodes = uData.deleteCodes;
  1530. let billsLibId = uData.billsLibId;
  1531. if(type === 'create'){
  1532. ItemCharacter.update({billsLibId: billsLibId, id: updateId}, {$addToSet: {itemValue: data}}, function(err){
  1533. if(err){
  1534. callback(1, 'Error');
  1535. }
  1536. else{
  1537. callback(0, '');
  1538. }
  1539. });
  1540. }
  1541. else if(type === 'update'){
  1542. if(data.field === 'code'){
  1543. ItemCharacter.update({billsLibId: billsLibId, id: updateId, 'itemValue.code': data.code}, {$set: {'itemValue.$.code': data.newData}}, function(err){
  1544. if(err){
  1545. callback(1, 'Error');
  1546. }
  1547. else{
  1548. callback(0, '');
  1549. }
  1550. });
  1551. }
  1552. else {
  1553. ItemCharacter.update({billsLibId: billsLibId, id: updateId, 'itemValue.code': data.code}, {$set: {'itemValue.$.value': data.newData}}, function(err,result){
  1554. if(err){
  1555. callback(1, 'Error');
  1556. }
  1557. else{
  1558. console.log(`suc`);
  1559. console.log(result);
  1560. callback(0, '');
  1561. }
  1562. });
  1563. }
  1564. }
  1565. //delete
  1566. else {
  1567. if(deleteCodes.length > 0){
  1568. async.each(deleteCodes, function(code, cb){
  1569. ItemCharacter.update({billsLibId: billsLibId, id: updateId}, {$pull: {itemValue: {code: code}}}, function(err){
  1570. if(err){
  1571. cb(err);
  1572. }else {
  1573. cb(null);
  1574. }
  1575. });
  1576. }, function(err){
  1577. if(err){
  1578. callback(1, 'Error');
  1579. }else {
  1580. callback(0, '');
  1581. }
  1582. });
  1583. }
  1584. }
  1585. };
  1586. billsLibDao.prototype.deleteItemCharacter = function(data, callback){
  1587. let delIds = data.ids;
  1588. let billsLibId = data.billsLibId;
  1589. if(delIds){
  1590. async.each(delIds, function(id, cb){
  1591. ItemCharacter.update({billsLibId: billsLibId, id: id}, {$set: {deleted: true}}, function(err){
  1592. if(err){
  1593. cb(err);
  1594. }else {
  1595. cb(null);
  1596. }
  1597. }, function(err){
  1598. if(err){
  1599. callback(1, 'Error');
  1600. }else {
  1601. callback(0, '');
  1602. }
  1603. });
  1604. });
  1605. }
  1606. };
  1607. billsLibDao.prototype.pasteItems = function (data, callback) {
  1608. let pasteDatas = data.pasteDatas;
  1609. let updateDatas = pasteDatas.updateDatas,
  1610. createDatas = pasteDatas.createDatas;
  1611. let functions = [];
  1612. let parallelFucs = {
  1613. updateFuc: function(data){
  1614. let updateId = data.orgId,
  1615. field = data.field,
  1616. updateData = data.data, billsLibId = data.billsLibId;
  1617. if(field === 'code'){
  1618. return function (cb){
  1619. ItemCharacter.update({billsLibId: billsLibId, id: updateId}, {$set: {code: updateData}}, function(err){
  1620. if(err){
  1621. cb(err);
  1622. }else {
  1623. cb(null, data);
  1624. }
  1625. });
  1626. };
  1627. }
  1628. else{
  1629. return function(cb){
  1630. ItemCharacter.update({billsLibId: billsLibId, id: updateId}, {$set: {content: updateData}}, function(err){
  1631. if(err){
  1632. cb(err);
  1633. }else {
  1634. cb(null, data);
  1635. }
  1636. });
  1637. }
  1638. }
  1639. },
  1640. createFuc: function(data){
  1641. let billsLibId = data.billsLibId,
  1642. code;
  1643. let itemObj;
  1644. if(data.type === 'CreateT'){
  1645. itemObj = {
  1646. billsLibId: billsLibId,
  1647. code: data.code,
  1648. content: data.content,
  1649. deleted: false
  1650. }
  1651. }
  1652. else{
  1653. if(data.field === 'code'){
  1654. itemObj = {
  1655. billsLibId: billsLibId,
  1656. code: data.data,
  1657. content: '',
  1658. deleted: false
  1659. }
  1660. }
  1661. else {
  1662. itemObj = {
  1663. billsLibId: billsLibId,
  1664. code: data.code,
  1665. content: data.data,
  1666. deleted: false
  1667. }
  1668. }
  1669. }
  1670. return function (cb){
  1671. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function(err, result){
  1672. if(err){
  1673. cb(err);
  1674. }
  1675. else{
  1676. let newItemId = result.value.sequence_value;
  1677. itemObj.id = newItemId;
  1678. data.newItemId = newItemId;
  1679. ItemCharacter.create(itemObj, function(err){
  1680. if(err){
  1681. cb(err);
  1682. }else {
  1683. cb(null, data);
  1684. }
  1685. });
  1686. }
  1687. });
  1688. }
  1689. }
  1690. };
  1691. if(updateDatas.length > 0){
  1692. for(let i=0; i<updateDatas.length; i++){
  1693. functions.push(parallelFucs.updateFuc(updateDatas[i]));
  1694. }
  1695. }
  1696. if(createDatas.length > 0){
  1697. for(let i =0; i<createDatas.length; i++){
  1698. functions.push(parallelFucs.createFuc(createDatas[i]));
  1699. }
  1700. }
  1701. async.parallel(functions, function(err, datas){
  1702. if(err){
  1703. callback(1, 'Error', null);
  1704. }else {
  1705. callback(0, '', datas);
  1706. }
  1707. });
  1708. };
  1709. billsLibDao.prototype.pasteValues = function(data, callback) {
  1710. let pasteDatas = data.pasteDatas;
  1711. let updateDatas = pasteDatas.updateDatas, createDatas = pasteDatas.createDatas;
  1712. let functions = [];
  1713. let parallelFucs = {
  1714. updateFuc: function(data){
  1715. let billsLibId = data.billsLibId, itemId = data.itemId, orgCode = data.orgId;
  1716. if (data.type === 'UpdateT') {
  1717. let valueObj = {code: data.code, value: data.content};
  1718. return function (cb){
  1719. ItemCharacter.update({billsLibId: billsLibId, id: itemId}, {$pull: {itemValue: {code: orgCode}}}, function (err) {
  1720. if (err) {
  1721. cb(err);
  1722. }
  1723. else {
  1724. ItemCharacter.update({billsLibId: billsLibId, id: itemId}, {$addToSet: {itemValue: valueObj}}, function (err) {
  1725. if (err) {
  1726. cb(err);
  1727. }
  1728. else {
  1729. cb(null, data);
  1730. }
  1731. });
  1732. }
  1733. });
  1734. };
  1735. }
  1736. else if (data.type === 'Update' && data.field === 'code') {
  1737. return function (cb) {
  1738. ItemCharacter.update({billsLibId: billsLibId, id: itemId, 'itemValue.code': orgCode},
  1739. {$set: {'itemValue.$.code': data.data}}, function (err) {
  1740. if(err){
  1741. cb(err);
  1742. }
  1743. else {
  1744. cb(null, data);
  1745. }
  1746. });
  1747. }
  1748. }
  1749. else {
  1750. return function (cb){
  1751. ItemCharacter.update({billsLIbId: billsLibId, id: itemId, 'itemValue.code': orgCode}, {$set: {'itemValue.$.value': data.data}}, function(err){
  1752. if(err){
  1753. cb(err);
  1754. }
  1755. else {
  1756. cb(null, data);
  1757. }
  1758. });
  1759. };
  1760. }
  1761. },
  1762. createFuc: function(data){
  1763. let valueObj;
  1764. if(data.type === 'CreateT'){
  1765. valueObj = {code: data.code, value: data.content};
  1766. return function (cb){
  1767. ItemCharacter.update({billsLibId: data.billsLibId, id: data.itemId}, {$addToSet: {itemValue: valueObj}}, function (err) {
  1768. if (err) {
  1769. cb(err);
  1770. }
  1771. else {
  1772. cb(null, data);
  1773. }
  1774. });
  1775. };
  1776. }
  1777. else if(data.type === 'Create' && data.field === 'code'){
  1778. valueObj = {code: data.data, value: ''};
  1779. return function (cb){
  1780. ItemCharacter.update({billsLibId: data.billsLibId, id: data.itemId}, {$addToSet: {itemValue: valueObj}}, function (err) {
  1781. if (err) {
  1782. cb(err);
  1783. }
  1784. else {
  1785. cb(null, data);
  1786. }
  1787. });
  1788. };
  1789. }
  1790. else {
  1791. valueObj = {code: data.code, value: data.data};
  1792. return function(cb){
  1793. ItemCharacter.update({billsLibId: data.billsLibId, id: data.itemId}, {$addToSet: {itemValue: valueObj}}, function (err) {
  1794. if (err) {
  1795. cb(err);
  1796. }
  1797. else {
  1798. cb(null, data);
  1799. }
  1800. });
  1801. };
  1802. }
  1803. }
  1804. };
  1805. if (updateDatas.length > 0) {
  1806. for (let i = 0; i < updateDatas.length; i++) {
  1807. functions.push(parallelFucs.updateFuc(updateDatas[i]));
  1808. }
  1809. }
  1810. if(createDatas.length >0){
  1811. for(let i=0; i< createDatas.length; i++){
  1812. functions.push(parallelFucs.createFuc(createDatas[i]));
  1813. }
  1814. }
  1815. async.parallel(functions, function(err, datas){
  1816. if(err){
  1817. callback(1, 'Error', null);
  1818. }
  1819. else {
  1820. callback(0, '', datas);
  1821. }
  1822. });
  1823. };
  1824. billsLibDao.prototype.edCreateItem = function(data, callback){
  1825. let billsLibId = data.billsLibId,
  1826. code = data.code,
  1827. billsId = data.billsId,
  1828. content = data.data;
  1829. async.waterfall([
  1830. function(cb){
  1831. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function(err, result){
  1832. if(err){
  1833. cb(err, null);
  1834. }
  1835. else {
  1836. let newItemId = result.value.sequence_value;
  1837. cb(null, newItemId);
  1838. }
  1839. })
  1840. },
  1841. function(newItemId, cb){
  1842. async.parallel([
  1843. function(pcb){
  1844. ItemCharacter.create({id: newItemId, billsLibId: billsLibId, code: code, content: content, deleted: false}, function(err){
  1845. if(err){
  1846. pcb(err, null);
  1847. }
  1848. else {
  1849. pcb(null, newItemId);
  1850. }
  1851. });
  1852. },
  1853. function(pcb){
  1854. Bills.update({billsLibId: billsLibId, ID: billsId, deleted: false}, {$addToSet: {items: newItemId}}, function(err){
  1855. if(err){
  1856. pcb(err, null);
  1857. }
  1858. else {
  1859. pcb(null, newItemId);
  1860. }
  1861. });
  1862. }
  1863. ], function(err, result){
  1864. if(err){
  1865. cb(err, null);
  1866. }
  1867. else {
  1868. cb(null, result[0]);
  1869. }
  1870. });
  1871. }
  1872. ], function(err, reslut){
  1873. if(err){
  1874. callback(1, "Error", null);
  1875. }
  1876. else {
  1877. callback(0, '', reslut);
  1878. }
  1879. });
  1880. };
  1881. billsLibDao.prototype.edUpdateItem = function(data, callback){
  1882. let billsLibId = data.billsLibId,
  1883. billsId = data.billsId,
  1884. content = data.content,
  1885. code = data.code,
  1886. orgItemId = data.orgItemId;
  1887. async.waterfall([
  1888. function(cb){
  1889. counter.counterDAO.getIDAfterCount(counter.moduleName.billsLib_items, 1, function(err, result){
  1890. if(err){
  1891. cb(err, null);
  1892. }
  1893. else {
  1894. let newItemId = result.value.sequence_value;
  1895. cb(null, newItemId);
  1896. }
  1897. })
  1898. },
  1899. function(newItemId, cb){
  1900. async.parallel([
  1901. function(pcb){
  1902. ItemCharacter.create({id: newItemId, billsLibId: billsLibId, code: code, content: content, deleted: false}, function(err){
  1903. if(err){
  1904. pcb(err, null);
  1905. }
  1906. else {
  1907. pcb(null, newItemId);
  1908. }
  1909. });
  1910. },
  1911. function(pcb){
  1912. Bills.update({billsLibId: billsLibId, ID: billsId, deleted: false, items: orgItemId}, {$set: {'items.$': newItemId}}, function(err){
  1913. if(err){
  1914. pcb(err, null);
  1915. }
  1916. else {
  1917. pcb(null, newItemId);
  1918. }
  1919. });
  1920. }
  1921. ], function(err, result){
  1922. if(err){
  1923. cb(err, null);
  1924. }
  1925. else {
  1926. cb(null, result[0]);
  1927. }
  1928. });
  1929. }
  1930. ], function(err, reslut){
  1931. if(err){
  1932. callback(1, "Error", null);
  1933. }
  1934. else {
  1935. callback(0, '', reslut);
  1936. }
  1937. });
  1938. };
  1939. //
  1940. module.exports = new billsLibDao();