rpt_construct_data_util.js 71 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753
  1. /**
  2. * Created by Tony on 2017/7/14.
  3. * 报表数据提取class,是协助报表模板里指标字段自主提取数据的工具类
  4. */
  5. let JV = require('../rpt_component/jpc_value_define');
  6. let $JE = require('../rpt_component/jpc_rte');
  7. let consts = require('../../../modules/main/models/project_consts');
  8. let fsUtil = require("../../../public/fsUtil");
  9. let stringUtil = require("../../../public/stringUtil");
  10. let treeUtil = require('../../../public/treeUtil');
  11. let projectConst = consts.projectConst;
  12. let projectConstList = consts.projectConstList;
  13. const gljUtil = require('../../../public/gljUtil');
  14. const gljType = require('../../common/const/glj_type_const');
  15. // const pm_facade = require('../../pm/facade/pm_facade');
  16. const GLJID_PRE = `gljId_`, COMPONENT_GLJID_PRE = `componetGljId_`;
  17. //import common_const = require('../../../public/common_constants');
  18. const { fixedFlag, supplyType, supplyText } = require('../../../public/common_constants');
  19. const _ = require('lodash');
  20. const scMathUtil = require('../../../public/scMathUtil').getUtil();
  21. const GLJ_TYPE = {
  22. Labour: 1,
  23. Material: 2,
  24. Machine: 3,
  25. Main_Material: 4,
  26. Equipment: 5,
  27. OTHER_MATERIAL: 207,
  28. MACHINE_LABOUR: 303,
  29. INSTRUMENT: 304,
  30. FUEL_POWER_FEE: 305
  31. };
  32. const oprMachines = [306, 307, 308, 309, 310, 311, 312];
  33. class Rpt_Common{
  34. initialize(rpt_tpl, currentDataObj) {
  35. this.template = rpt_tpl;
  36. this.currentDataObj = currentDataObj;
  37. };
  38. Multiply(val1, val2, fixFormat) {
  39. let rst = [], maxLen = val1.length, minLen = val2.length;
  40. if (minLen > maxLen) {
  41. maxLen = maxLen + minLen; minLen = maxLen - minLen; maxLen = maxLen - minLen;
  42. }
  43. for (let i = 0; i < maxLen; i++) {
  44. let value = ((i < val1.length)?val1[i]:val1[minLen - 1]) * ((i < val2.length)?val2[i]:val2[minLen - 1]);
  45. if (value === null || value === undefined) {
  46. value = '0';
  47. }
  48. if (fixFormat) value = value.toFixed(fixFormat);
  49. rst.push(value);
  50. }
  51. return rst;
  52. };
  53. Divide(val1, val2, fixFormat) {
  54. let rst = [], maxLen = val1.length, minLen = val2.length;
  55. if (minLen > maxLen) {
  56. maxLen = maxLen + minLen; minLen = maxLen - minLen; maxLen = maxLen - minLen;
  57. }
  58. for (let i = 0; i < maxLen; i++) {
  59. let value = ((i < val1.length)?val1[i]:val1[minLen - 1]) / ((i < val2.length)?val2[i]:val2[minLen - 1]);
  60. if (fixFormat) value = value.toFixed(fixFormat);
  61. rst.push(value);
  62. }
  63. return rst;
  64. };
  65. Plus(val1, val2, fixFormat) {
  66. let rst = [], maxLen = val1.length, minLen = val2.length;
  67. if (minLen > maxLen) {
  68. maxLen = maxLen + minLen; minLen = maxLen - minLen; maxLen = maxLen - minLen;
  69. }
  70. for (let i = 0; i < maxLen; i++) {
  71. let value = ((i < val1.length)?val1[i]:val1[minLen - 1]) + ((i < val2.length)?val2[i]:val2[minLen - 1]);
  72. if (fixFormat) value = value.toFixed(fixFormat);
  73. rst.push(value);
  74. }
  75. return rst;
  76. };
  77. MultiPlus(arrVal, fixFormat) {
  78. let rst = [];
  79. for (let i = 0; i < arrVal.length; i++) {
  80. let valItem = arrVal[i];
  81. if (i === 0) {
  82. for (let dtl of valItem) {
  83. let value = parseFloat(dtl);
  84. if (fixFormat) value = value.toFixed(fixFormat);
  85. rst.push(value);
  86. }
  87. } else {
  88. for (let j = 0; j < valItem.length; j++) {
  89. if (j < rst.length) {
  90. let value = rst[j] + valItem[j];
  91. if (fixFormat) value = value.toFixed(fixFormat);
  92. rst[j] = value;
  93. } else {
  94. let value = parseFloat(valItem[j]);
  95. if (fixFormat) value = value.toFixed(fixFormat);
  96. rst.push(value);
  97. }
  98. }
  99. }
  100. }
  101. return rst;
  102. };
  103. Minus(val1, val2, fixFormat) {
  104. let rst = [], maxLen = val1.length, minLen = val2.length;
  105. if (minLen > maxLen) {
  106. maxLen = maxLen + minLen; minLen = maxLen - minLen; maxLen = maxLen - minLen;
  107. }
  108. for (let i = 0; i < maxLen; i++) {
  109. let value = ((i < val1.length)?val1[i]:val1[minLen - 1]) - ((i < val2.length)?val2[i]:val2[minLen - 1]);
  110. if (fixFormat) value = value.toFixed(fixFormat);
  111. rst.push(value);
  112. }
  113. return rst;
  114. };
  115. FormatString(arrVal, formatStr){
  116. let rst = [];
  117. for (let val of arrVal) {
  118. rst.push(stringUtil.replaceAll(formatStr, '%S', val));
  119. }
  120. return rst;
  121. };
  122. getSupplyType(srcValArr) {
  123. let rst = [];
  124. for (const val of srcValArr) {
  125. let hasKey = false;
  126. for (const propKey in supplyType) {
  127. if (supplyType[propKey] === val) {
  128. hasKey = true;
  129. rst.push(supplyText[propKey]);
  130. break;
  131. }
  132. }
  133. if (!hasKey) {
  134. rst.push('未知方式');
  135. }
  136. }
  137. return rst;
  138. };
  139. }
  140. class Rpt_Data_Extractor {
  141. constructor () {
  142. this.COMMON = new Rpt_Common();
  143. };
  144. initialize(tpl) {
  145. this.rptTpl = tpl;
  146. };
  147. //-- 根据报表模板映射指标(非离散指标)的定义,罗列出所有需要用到的data对象key,作为数据请求的过滤依据
  148. getDataRequestFilter(summaryRst, economicRst) {
  149. let rst = [];
  150. let tpl = this.rptTpl;
  151. let pri_func_chk_filter = function (field) {
  152. for (let key of projectConstList) {
  153. if (rst.indexOf(key) < 0) {
  154. if (field[JV.PROP_FIELD_EXP_MAP]) {
  155. if (field[JV.PROP_FIELD_EXP_MAP].indexOf('.' + key + '.') >= 0) {
  156. rst.push(key);
  157. if (key === projectConst.RATION_GLJ && (rst.indexOf(projectConst.PROJECTGLJ) < 0)) {
  158. rst.push(projectConst.PROJECTGLJ);
  159. if (rst.indexOf(projectConst.LABOUR_COE < 0)) rst.push(projectConst.LABOUR_COE);
  160. }
  161. if (key === projectConst.PROJECTGLJ) {
  162. if (rst.indexOf(projectConst.LABOUR_COE) < 0) rst.push(projectConst.LABOUR_COE);
  163. if (rst.indexOf(projectConst.RATION_GLJ) < 0) rst.push(projectConst.RATION_GLJ);
  164. if (field[JV.PROP_FIELD_EXP_MAP].indexOf("'quantity'") > 0 ||
  165. field[JV.PROP_FIELD_EXP_MAP].indexOf("'subdivisionQuantity'") > 0 ||
  166. field[JV.PROP_FIELD_EXP_MAP].indexOf("'techQuantity'") > 0 ) {
  167. if (rst.indexOf(projectConst.RATION) < 0) rst.push(projectConst.RATION);
  168. if (rst.indexOf(projectConst.BILLS) < 0) rst.push(projectConst.BILLS);
  169. }
  170. }
  171. if (key === projectConst.CONTRACTOR_LIST) {
  172. if (rst.indexOf(projectConst.PROJECTGLJ) < 0) {
  173. rst.push(projectConst.PROJECTGLJ); //为了算指标:承包人主要材料设备_变值权重B
  174. }
  175. if (rst.indexOf(projectConst.BILLS) < 0) {
  176. rst.push(projectConst.BILLS); //为了算指标:承包人主要材料设备_变值权重B
  177. }
  178. }
  179. }
  180. }
  181. } else if (key === projectConst.PROJECTGLJ) {
  182. if (rst.indexOf(projectConst.RATION_GLJ) < 0) rst.push(projectConst.RATION_GLJ);
  183. if (field[JV.PROP_FIELD_EXP_MAP].indexOf("'quantity'") > 0 ||
  184. field[JV.PROP_FIELD_EXP_MAP].indexOf("'subdivisionQuantity'") > 0 ||
  185. field[JV.PROP_FIELD_EXP_MAP].indexOf("'techQuantity'") > 0 ) {
  186. if (rst.indexOf(projectConst.RATION) < 0) rst.push(projectConst.RATION);
  187. if (rst.indexOf(projectConst.BILLS) < 0) rst.push(projectConst.BILLS);
  188. }
  189. }
  190. }
  191. if (summaryRst instanceof Array) {
  192. for (let key of consts.summaryConstList) {
  193. if (summaryRst.indexOf(key) < 0) {
  194. if (field[JV.PROP_FIELD_EXP_MAP]) {
  195. if (field[JV.PROP_FIELD_EXP_MAP].indexOf('.' + key + '.') >= 0) {
  196. summaryRst.push(key);
  197. }
  198. }
  199. }
  200. }
  201. }
  202. if (economicRst instanceof Array) {
  203. for (let key of consts.projectFieldConstList) {
  204. if (economicRst.indexOf(key) < 0) {
  205. if (field[JV.PROP_FIELD_EXP_MAP]) {
  206. if (field[JV.PROP_FIELD_EXP_MAP].indexOf('.' + key + '.') >= 0) {
  207. economicRst.push(key);
  208. }
  209. }
  210. }
  211. }
  212. }
  213. };
  214. let pri_setup_filter = function (FIELD_LIST_KEY) {
  215. if (tpl[JV.NODE_FIELD_MAP][FIELD_LIST_KEY]) {
  216. for (let field of tpl[JV.NODE_FIELD_MAP][FIELD_LIST_KEY]) {
  217. pri_func_chk_filter(field);
  218. }
  219. }
  220. };
  221. pri_setup_filter(JV.NODE_DISCRETE_FIELDS);
  222. pri_setup_filter(JV.NODE_MASTER_FIELDS);
  223. pri_setup_filter(JV.NODE_DETAIL_FIELDS);
  224. pri_setup_filter(JV.NODE_MASTER_FIELDS_EX);
  225. pri_setup_filter(JV.NODE_DETAIL_FIELDS_EX);
  226. if (tpl[JV.NODE_MAP_DATA_HANDLE_INFO] && tpl[JV.NODE_MAP_DATA_HANDLE_INFO].length > 0) {
  227. for (let preHandle of tpl[JV.NODE_MAP_DATA_HANDLE_INFO]) {
  228. if (rst.indexOf(preHandle[JV.PROP_DATA_KEY]) < 0) {
  229. rst.push(preHandle[JV.PROP_DATA_KEY]);
  230. }
  231. if (preHandle[JV.PROP_HANDLE_TYPE] === JV.PROP_HANDLE_TYPE_FILTER) {
  232. if (preHandle[JV.PROP_FILTER_KEYS]) {
  233. for (let filter of preHandle[JV.PROP_FILTER_KEYS]) {
  234. if (filter[JV.PROP_FILTER_COMPARE_OBJ] && rst.indexOf(filter[JV.PROP_FILTER_COMPARE_OBJ]) < 0) {
  235. rst.push(filter[JV.PROP_FILTER_COMPARE_OBJ]);
  236. }
  237. }
  238. }
  239. } else if (preHandle[JV.PROP_HANDLE_TYPE] === JV.PROP_HANDLE_TYPE_SUM) {
  240. if (preHandle[JV.PROP_SUM_GROUP_KEYS]) {
  241. for (let grpKey of preHandle[JV.PROP_SUM_GROUP_KEYS]) {
  242. if (grpKey.seeking_parent && rst.indexOf(grpKey.seeking_parent) < 0) {
  243. rst.push(grpKey.seeking_parent);
  244. }
  245. }
  246. }
  247. } else if (preHandle[JV.PROP_PARENT_CHILD_SORT_KEY] && preHandle[JV.PROP_PARENT_CHILD_SORT_KEY].length > 0) {
  248. for (let item of preHandle[JV.PROP_PARENT_CHILD_SORT_KEY]) {
  249. if (rst.indexOf(item[JV.PROP_PARENT_DATA_KEY]) < 0) {
  250. rst.push(item[JV.PROP_PARENT_DATA_KEY]);
  251. }
  252. }
  253. }
  254. }
  255. }
  256. if (rst.length === 0) {
  257. rst.push(projectConst.RATION_ASS);
  258. }
  259. return rst;
  260. };
  261. //--- 装配数据(把收集到的数据,依据报表模板的指示,预处理(如:排序、过滤、合计)及装配到相关指标) ---//
  262. assembleData(rawDataObj) {
  263. let $PROJECT = {"COMMON": null, "MAIN": {}, "DETAIL": {}};
  264. let tpl = this.rptTpl;
  265. this.COMMON.initialize(tpl, rawDataObj);
  266. $PROJECT.COMMON = this.COMMON;
  267. if (rawDataObj.hasOwnProperty(`prj`)) {
  268. setupMainFunc($PROJECT, `MAIN`, rawDataObj.prj._doc);
  269. // $PROJECT.MAIN["myOwnRawDataObj"] = rawDataObj.prj._doc;
  270. // $PROJECT.MAIN.getProperty = ext_mainGetPropety;
  271. // $PROJECT.MAIN.getFee = ext_mainGetFee;
  272. for (let item of rawDataObj.prjData) {
  273. setupFunc($PROJECT.DETAIL, item.moduleName, item);
  274. }
  275. let projectGLJDatas = getModuleDataByKey(rawDataObj.prjData, "projectGLJ");
  276. if (projectGLJDatas) {
  277. //增加一个辅助对象,方便通过gljid key直接获取数据,省去循环时间
  278. let gljAssitantObj = {"gljIds": {}, "componentGljIds": {}};
  279. projectGLJDatas.data.gljAssistant = gljAssitantObj;
  280. for (let gljItem of projectGLJDatas.data.gljList) {
  281. gljAssitantObj.gljIds[GLJID_PRE + gljItem.id] = gljItem;
  282. if (!(gljItem.ratio_data) || gljItem.ratio_data.length === 0) {
  283. gljAssitantObj.componentGljIds[COMPONENT_GLJID_PRE + gljItem.glj_id] = gljItem;
  284. }
  285. }
  286. }
  287. let labourCoeDatas = getModuleDataByKey(rawDataObj.prjData, "labour_coe");
  288. let rationGLJDatas = getModuleDataByKey(rawDataObj.prjData, "ration_glj");
  289. let rationDatas = getModuleDataByKey(rawDataObj.prjData, "ration");
  290. let billsDatas = getModuleDataByKey(rawDataObj.prjData, "bills");
  291. let contractorDatas = getModuleDataByKey(rawDataObj.prjData, "contractor_list");
  292. let decimal = rawDataObj.prj.property.decimal.glj.quantity;
  293. let calcOptions = rawDataObj.prj.property.calcOptions;
  294. if (projectGLJDatas && rationGLJDatas && rationDatas && billsDatas) {
  295. gljUtil.calcProjectGLJQuantity(projectGLJDatas.data, rationGLJDatas.data, rationDatas.data, billsDatas.data, decimal, true);
  296. }
  297. if (contractorDatas && projectGLJDatas && billsDatas) {
  298. let ttlFee = 0;
  299. for (const bd of billsDatas.data) {
  300. let doc = bd._doc ? bd._doc : bd;
  301. let hasTtl = false;
  302. if (doc.flags && doc.flags.length > 0) {
  303. for (const flag of doc.flags) {
  304. let flagDoc = flag._doc ? flag._doc : flag;
  305. if (flagDoc.flag === fixedFlag.ENGINEERINGCOST) {
  306. hasTtl = true;
  307. break;
  308. }
  309. }
  310. }
  311. if (hasTtl) {
  312. for (const fee of bd.fees) {
  313. let feeDoc = fee._doc ? fee._doc : fee;
  314. if (feeDoc.fieldName === 'common') {
  315. // console.log(feeDoc);
  316. ttlFee = feeDoc.totalFee;
  317. break;
  318. }
  319. }
  320. break;
  321. }
  322. }
  323. let coeRst = gljUtil.getPriceCoeDatas(projectGLJDatas.data.gljList, contractorDatas.data, ttlFee, rawDataObj.prj.property, _, scMathUtil);
  324. console.log(coeRst);
  325. contractorDatas.data = coeRst;
  326. }
  327. if (projectGLJDatas && rationGLJDatas && labourCoeDatas) {
  328. //考虑调价情况
  329. const newAdjPriceArr = [];
  330. // console.log('1');
  331. // console.log(projectGLJDatas.data.gljList);
  332. for (const glj of projectGLJDatas.data.gljList) {
  333. newAdjPriceArr.push(gljUtil.getGLJPrice(glj, projectGLJDatas.data, calcOptions, labourCoeDatas, rawDataObj.prj.property.decimal, false, gljUtil.getTenderPriceCoe(glj, rawDataObj.prj.property), true));
  334. // glj.unit_price.market_price_tender = gljUtil.getMarketPrice(glj, projectGLJDatas.data, calcOptions, rawDataObj.prj.property.decimal, false, gljUtil.getTenderPriceCoe(glj, rawDataObj.prj.property));
  335. }
  336. // console.log('2');
  337. for (let gljIdx = 0; gljIdx < newAdjPriceArr.length; gljIdx++) {
  338. let newGlj = newAdjPriceArr[gljIdx];
  339. let gljItem = projectGLJDatas.data.gljList[gljIdx];
  340. gljItem.unit_price.market_price_tender = newGlj.marketPrice;
  341. gljItem.unit_price.org_basePrice = gljItem.unit_price.base_price;
  342. gljItem.unit_price.base_price = newGlj.basePrice;
  343. // rationItem.marketUnitFee = newGlj.marketPrice;//更新树节点市场单价列的值
  344. //
  345. }
  346. // console.log('3');
  347. }
  348. }
  349. //还有汇总的...
  350. if (rawDataObj.hasOwnProperty(`Construct`) || rawDataObj.hasOwnProperty(`ConstructDetail`) || rawDataObj.hasOwnProperty(`Segment`) || rawDataObj.hasOwnProperty(`SegmentDetail`)) {
  351. $PROJECT.SUMMARY = {};
  352. if (rawDataObj.Construct) {
  353. setupMainFunc($PROJECT.SUMMARY, `Construct`, rawDataObj.Construct);
  354. }
  355. if (rawDataObj.ConstructDetail) {
  356. setupFunc($PROJECT.SUMMARY, `ConstructDetail`, {"data": rawDataObj.ConstructDetail});
  357. }
  358. if (rawDataObj.Segment) {
  359. setupMainFunc($PROJECT.SUMMARY, `Segment`, rawDataObj.Segment);
  360. }
  361. if (rawDataObj.SegmentDetail) {
  362. setupFunc($PROJECT.SUMMARY, `SegmentDetail`, {"data": rawDataObj.SegmentDetail});
  363. }
  364. }
  365. if (tpl[JV.NODE_MAP_DATA_HANDLE_INFO]) {
  366. for (let preHandle of tpl[JV.NODE_MAP_DATA_HANDLE_INFO]) {
  367. let srcData = getModuleDataByKey(rawDataObj.prjData, preHandle[JV.PROP_DATA_KEY]);
  368. switch(preHandle[JV.PROP_HANDLE_TYPE]) {
  369. case JV.PROP_HANDLE_TYPE_SORT:
  370. sortData(srcData, preHandle, rawDataObj.prjData);
  371. break;
  372. case JV.PROP_HANDLE_TYPE_FILTER:
  373. filterData(srcData, preHandle, rawDataObj.prjData);
  374. break;
  375. case JV.PROP_HANDLE_TYPE_SUM:
  376. // fsUtil.writeObjToFile(rawDataObj, "D:/GitHome/ConstructionCost/tmp/insertedRawDataData10.jsp");
  377. summaryData(srcData, preHandle, rawDataObj.prjData, rawDataObj.prj);
  378. // fsUtil.writeObjToFile(rawDataObj, "D:/GitHome/ConstructionCost/tmp/insertedRawDataData11.jsp");
  379. break;
  380. case JV.PROP_HANDLE_TYPE_ADD_DUMMY:
  381. addDummyData(srcData, preHandle);
  382. break;
  383. case JV.PROP_HANDLE_TYPE_ADJUST:
  384. adjustData(srcData, preHandle);
  385. break;
  386. case JV.PROP_HANDLE_TYPE_BILLS_DATA_MOVE:
  387. //把显示在清单中的量材转移到工料机去
  388. moveRationData(srcData, rawDataObj);
  389. break;
  390. case JV.PROP_HANDLE_TYPE_COMPONENT_REPLACEMENT:
  391. //重庆2018 09-x表专用,机械数据用 组成物替换掉 ^_^!
  392. componentReplacement(rawDataObj);
  393. break;
  394. default:
  395. break;
  396. }
  397. }
  398. }
  399. let rptDataObj = {};
  400. rptDataObj[JV.DATA_DISCRETE_DATA] = [];
  401. rptDataObj[JV.DATA_MASTER_DATA] = [];
  402. rptDataObj[JV.DATA_DETAIL_DATA] = [];
  403. rptDataObj[JV.DATA_MASTER_DATA_EX] = [];
  404. rptDataObj[JV.DATA_DETAIL_DATA_EX] = [];
  405. rptDataObj.DecimalObj = {};
  406. rptDataObj.DecimalObj.prjDecimal = $PROJECT.MAIN["myOwnRawDataObj"].decimal; //为函数 P_REF() 准备数据
  407. rptDataObj.DecimalObj.unitDecimal = getUnitDecimal($PROJECT.MAIN["myOwnRawDataObj"].billsQuantityDecimal); //为函数 U_REF() 准备数据
  408. assembleFields(tpl[JV.NODE_FIELD_MAP][JV.NODE_DISCRETE_FIELDS], rptDataObj[JV.DATA_DISCRETE_DATA], $PROJECT);
  409. // console.log(JV.DATA_DISCRETE_DATA);
  410. // console.log(rptDataObj[JV.DATA_DISCRETE_DATA]);
  411. assembleFields(tpl[JV.NODE_FIELD_MAP][JV.NODE_MASTER_FIELDS], rptDataObj[JV.DATA_MASTER_DATA], $PROJECT);
  412. // console.log(JV.DATA_MASTER_DATA);
  413. // console.log(rptDataObj[JV.DATA_MASTER_DATA]);
  414. assembleFields(tpl[JV.NODE_FIELD_MAP][JV.NODE_DETAIL_FIELDS], rptDataObj[JV.DATA_DETAIL_DATA], $PROJECT);
  415. // console.log(JV.DATA_DETAIL_DATA);
  416. // console.log(rptDataObj[JV.DATA_DETAIL_DATA]);
  417. assembleFields(tpl[JV.NODE_FIELD_MAP][JV.NODE_MASTER_FIELDS_EX], rptDataObj[JV.DATA_MASTER_DATA_EX], $PROJECT);
  418. // console.log(JV.DATA_MASTER_DATA_EX);
  419. // console.log(rptDataObj[JV.DATA_MASTER_DATA_EX]);
  420. assembleFields(tpl[JV.NODE_FIELD_MAP][JV.NODE_DETAIL_FIELDS_EX], rptDataObj[JV.DATA_DETAIL_DATA_EX], $PROJECT);
  421. // console.log(JV.DATA_DETAIL_DATA_EX);
  422. // console.log(rptDataObj[JV.DATA_DETAIL_DATA_EX]);
  423. // fsUtil.writeObjToFile(rptDataObj, "D:/GitHome/ConstructionCost/tmp/insertedOriginalData.jsp");
  424. // fsUtil.writeObjToFile(rawDataObj, "D:/GitHome/ConstructionCost/tmp/insertedRawDataData.jsp");
  425. // fsUtil.writeObjToFile($PROJECT, "D:/GitHome/ConstructionCost/tmp/$PROJECTData.jsp");
  426. // fsUtil.writeObjToFile(tpl[JV.NODE_FIELD_MAP][JV.NODE_MASTER_FIELDS], "D:/GitHome/ConstructionCost/tmp/masterFieldsAfterAssemble.jsp");
  427. // fsUtil.writeObjToFile(tpl[JV.NODE_FIELD_MAP][JV.NODE_DETAIL_FIELDS], "D:/GitHome/ConstructionCost/tmp/detailFieldsAfterAssemble.jsp");
  428. return rptDataObj;
  429. };
  430. }
  431. //小数位数依据单位来调整(如吨、公斤的精度要求就不同)
  432. function getUnitDecimal(unitDecimalArr) {
  433. let rst = {"default_decimal": 2};
  434. if (unitDecimalArr) {
  435. for (let item of unitDecimalArr) {
  436. if (item.unit === "其他未列单位") {
  437. rst["default_decimal"] = item.decimal;
  438. } else {
  439. rst['unit_decimal_' + item.unit] = item.decimal;
  440. }
  441. }
  442. }
  443. return rst;
  444. }
  445. function getModuleDataByKey(prjData, key) {
  446. let rst = null;
  447. for (let item of prjData) {
  448. if (item.moduleName === key) {
  449. rst = item;
  450. break;
  451. }
  452. }
  453. return rst;
  454. }
  455. function summaryData(sourceData, handleCfg, prjData, prjMain){
  456. let rstArr = [], tempRstArr = [];
  457. let curParentPrjData = {};
  458. let precision = 6;
  459. if (handleCfg[JV.PROP_HANDLE_TYPE_PRECISION]) {
  460. if (isNaN(parseInt(handleCfg[JV.PROP_HANDLE_TYPE_PRECISION]))) {
  461. let properties = handleCfg[JV.PROP_HANDLE_TYPE_PRECISION].split('.');
  462. let currentProperty = prjMain[properties[0]];
  463. for (let idx = 1; idx < properties.length; idx++) {
  464. currentProperty = currentProperty[properties[idx]];
  465. }
  466. if (!isNaN(parseInt(currentProperty))) {
  467. precision = parseInt(currentProperty);
  468. }
  469. } else {
  470. precision = parseInt(handleCfg[JV.PROP_HANDLE_TYPE_PRECISION]);
  471. }
  472. }
  473. for (let item of getActDataArr(sourceData)) {
  474. if (item._doc) {
  475. tempRstArr.push(item._doc);
  476. } else {
  477. tempRstArr.push(item);
  478. }
  479. }
  480. let private_cal_before_sum = function () {
  481. for (let calcAheadObj of handleCfg[JV.PROP_SUM_CALC_AHEAD]) {
  482. if (!curParentPrjData[calcAheadObj["seeking_parent"]]) curParentPrjData[calcAheadObj["seeking_parent"]] = getModuleDataByKey(prjData, calcAheadObj["seeking_parent"]);
  483. for (let idxP = 0; idxP < curParentPrjData[calcAheadObj["seeking_parent"]].data.length; idxP++) {
  484. let pDataItem = curParentPrjData[calcAheadObj["seeking_parent"]].data[idxP];
  485. let data = (pDataItem._doc)?pDataItem._doc:pDataItem;
  486. for (let idx = 0; idx < tempRstArr.length; idx++) {
  487. let dtlItem = tempRstArr[idx];
  488. if (dtlItem[calcAheadObj["seeking_key"]] === data[calcAheadObj["parent_key"]]) {
  489. for (let sumKey of handleCfg[JV.PROP_SUM_SUM_KEYS]) {
  490. switch (calcAheadObj[JV.PROP_SUM_CACL_TYPE]) {
  491. case "+":
  492. dtlItem[sumKey] = parseFloat(dtlItem[sumKey]) + parseFloat(data[calcAheadObj["calc_property"]]);
  493. break;
  494. case "-":
  495. dtlItem[sumKey] = parseFloat(dtlItem[sumKey]) - parseFloat(data[calcAheadObj["calc_property"]]);
  496. break;
  497. case "*":
  498. dtlItem[sumKey] = dtlItem[sumKey] * parseFloat(data[calcAheadObj["calc_property"]]);
  499. break;
  500. case "/":
  501. dtlItem[sumKey] = dtlItem[sumKey] / parseFloat(data[calcAheadObj["calc_property"]]);
  502. break;
  503. default:
  504. break;
  505. }
  506. }
  507. // break;
  508. }
  509. }
  510. }
  511. }
  512. };
  513. let private_get_grp_key = function (item) {
  514. let keys = [];
  515. for (let cfg of handleCfg[JV.PROP_SUM_GROUP_KEYS]) {
  516. if (typeof cfg === "string") {
  517. keys.push(item[cfg]);
  518. } else {
  519. if (!curParentPrjData[cfg["seeking_parent"]]) curParentPrjData[cfg["seeking_parent"]] = getModuleDataByKey(prjData, cfg["seeking_parent"]);
  520. for (let pDataItem of curParentPrjData[cfg["seeking_parent"]].data) {
  521. let data = (pDataItem._doc)?pDataItem._doc:pDataItem;
  522. if (item[cfg["seeking_key"]] === data[cfg["parent_key"]]) {
  523. keys.push(data[cfg["parent_grp_key"]]);
  524. break;
  525. }
  526. }
  527. }
  528. }
  529. return ( "grp_key_" + keys.join('_'));
  530. };
  531. let sumObj = {};
  532. if (handleCfg[JV.PROP_SUM_CALC_AHEAD] && handleCfg[JV.PROP_SUM_CALC_AHEAD].length > 0) {
  533. private_cal_before_sum();
  534. }
  535. for (let dtl of tempRstArr) {
  536. let grpKey = private_get_grp_key(dtl);
  537. if (sumObj[grpKey] === null || sumObj[grpKey] === undefined) {
  538. sumObj[grpKey] = dtl;
  539. rstArr.push(dtl);
  540. } else {
  541. for (let sumKey of handleCfg[JV.PROP_SUM_SUM_KEYS]) {
  542. if (dtl[sumKey]) {
  543. // sumObj[grpKey][sumKey] += dtl[sumKey];
  544. sumObj[grpKey][sumKey] = parseFloat(parseFloat(sumObj[grpKey][sumKey]).toFixed(precision)) + parseFloat(parseFloat(dtl[sumKey]).toFixed(precision));
  545. }
  546. }
  547. }
  548. }
  549. replaceActDataArr(sourceData, rstArr);
  550. // fsUtil.writeObjToFile(sourceData.data, "D:/GitHome/ConstructionCost/tmp/sumRst.jsp");
  551. }
  552. function filterData(sourceData, handleCfg, prjData) {
  553. let rstArr = [], tempRstArr = [];
  554. for (let item of getActDataArr(sourceData)) {
  555. if (item._doc) {
  556. tempRstArr.push(item._doc);
  557. } else {
  558. tempRstArr.push(item);
  559. }
  560. }
  561. let private_chkVal = function (src, compVal, compStr) {
  562. let rst = true;
  563. switch (compStr) {
  564. case "==" :
  565. rst = (src == compVal);
  566. break;
  567. case "===" :
  568. rst = (src === compVal);
  569. break;
  570. case ">" :
  571. rst = (src > compVal);
  572. break;
  573. case ">=" :
  574. rst = (src >= compVal);
  575. break;
  576. case "<" :
  577. rst = (src < compVal);
  578. break;
  579. case "<=" :
  580. rst = (src <= compVal);
  581. break;
  582. case "!=" :
  583. rst = (src != compVal);
  584. break;
  585. case "!==" :
  586. rst = (src !== compVal);
  587. break;
  588. case "in" :
  589. if (compVal instanceof Array) {
  590. rst = compVal.indexOf(src) >= 0;
  591. } else {
  592. //string,需要转类型
  593. let newInCv = JSON.parse(compVal);
  594. if (newInCv instanceof Array) {
  595. rst = newInCv.indexOf(src) >= 0;
  596. } else {
  597. rst = false;
  598. }
  599. }
  600. break;
  601. case "not in":
  602. if (compVal instanceof Array) {
  603. rst = compVal.indexOf(src) < 0;
  604. } else {
  605. //string,需要转类型
  606. let newNotInCv = JSON.parse(compVal);
  607. if (newNotInCv instanceof Array) {
  608. rst = (newNotInCv.indexOf(src) < 0);
  609. } else {
  610. rst = true;
  611. }
  612. }
  613. break;
  614. default:
  615. rst = true;
  616. }
  617. return rst;
  618. };
  619. let private_chkArrVal = function(arr, key, compVal, compStr){
  620. let rst = false;
  621. if (arr.length > 0) {
  622. for (let arrItem of arr) {
  623. if (arrItem[key] !== undefined) {
  624. // 可以为null值去判断
  625. rst = private_chkVal(arrItem[key], compVal, compStr);
  626. }
  627. if (rst) {
  628. break;
  629. }
  630. }
  631. } else {
  632. //在某些判断条件下(含有'非'判断),如arr没有数组项,默认结果反而是true
  633. switch (compStr) {
  634. case "!=" :
  635. case "!==" :
  636. case "not in":
  637. rst = true;
  638. break;
  639. default:
  640. break;
  641. }
  642. }
  643. return rst;
  644. };
  645. let private_filter_compare = function (item, filterCfg) {
  646. let compareObj = {};
  647. let compRst = true;
  648. let curComparePrjData = null;
  649. let startIdx = 0;
  650. let private_ref_join = function(refKey, targetDataKey, targetPropertyKey) {
  651. let rst = null, objDataArr = null;
  652. curComparePrjData = getModuleDataByKey(prjData, targetDataKey);
  653. try {
  654. if (curComparePrjData !== null) {
  655. objDataArr = getActDataArr(curComparePrjData);
  656. for (let dtl of objDataArr) {
  657. if (item[refKey] === dtl[targetPropertyKey]) {
  658. rst = dtl;
  659. break;
  660. }
  661. }
  662. }
  663. } finally {
  664. curComparePrjData = null;
  665. }
  666. return rst;
  667. };
  668. for (let cfg of filterCfg[JV.PROP_FILTER_KEYS]) {
  669. if (cfg[JV.PROP_FILTER_COMPARE_VAL]) {
  670. //比较key值
  671. let keys = cfg.key.split(".");
  672. if (keys.length > 1) {
  673. let lastObj = item;
  674. for (let i = 0; i < keys.length - 1; i++) {
  675. if (keys[i].indexOf("ref_join(") === 0) {
  676. let params = keys[i].slice(9, keys[i].length - 1).split(",");
  677. if (params.length === 3) {
  678. lastObj = private_ref_join(params[0], params[1], params[2]);
  679. }
  680. if (!(lastObj)) {
  681. compRst = false;
  682. break;
  683. }
  684. } else {
  685. lastObj = item[keys[i]];
  686. if (!(lastObj)) {
  687. compRst = false;
  688. break;
  689. }
  690. }
  691. }
  692. if (lastObj) {
  693. if (lastObj instanceof Array) {
  694. compRst = private_chkArrVal(lastObj, keys[keys.length - 1], cfg[JV.PROP_FILTER_COMPARE_VAL], cfg[JV.PROP_FILTER_CONDITION]);
  695. } else {
  696. compRst = private_chkVal(lastObj[keys[keys.length - 1]], cfg[JV.PROP_FILTER_COMPARE_VAL], cfg[JV.PROP_FILTER_CONDITION]);
  697. }
  698. }
  699. } else {
  700. compRst = private_chkVal(item[cfg.key], cfg[JV.PROP_FILTER_COMPARE_VAL], cfg[JV.PROP_FILTER_CONDITION]);
  701. }
  702. } else if (cfg[JV.PROP_FILTER_COMPARE_OBJ] && cfg[JV.PROP_FILTER_COMPARE_OBJ_KEY]){
  703. //通过其他对象来过滤
  704. if (!curComparePrjData) {
  705. curComparePrjData = getModuleDataByKey(prjData, cfg[JV.PROP_FILTER_COMPARE_OBJ]);
  706. }
  707. if (cfg[JV.PROP_FILTER_CONDITION] === "in" || cfg[JV.PROP_FILTER_CONDITION] === "not in") {
  708. let compareArr = null;
  709. if (!compareObj.hasOwnProperty(cfg[JV.PROP_FILTER_COMPARE_OBJ_KEY] + startIdx.toString())) {
  710. compareObj[cfg[JV.PROP_FILTER_COMPARE_OBJ_KEY] + startIdx.toString()] = [];
  711. compareArr = compareObj[cfg[JV.PROP_FILTER_COMPARE_OBJ_KEY] + startIdx.toString()];
  712. for (let data of getActDataArr(curComparePrjData)) {
  713. if (compareArr.indexOf(data[cfg[JV.PROP_FILTER_COMPARE_OBJ_KEY]]) < 0) {
  714. compareArr.push(data[cfg[JV.PROP_FILTER_COMPARE_OBJ_KEY]]);
  715. }
  716. }
  717. } else {
  718. compareArr = compareObj[cfg[JV.PROP_FILTER_COMPARE_OBJ_KEY] + startIdx.toString()];
  719. }
  720. compRst = private_chkVal(item[cfg.key], compareArr, cfg[JV.PROP_FILTER_CONDITION]);
  721. } else {
  722. for (let data of getActDataArr(curComparePrjData)) {
  723. compRst = private_chkVal(item[cfg.key], data[cfg[JV.PROP_FILTER_COMPARE_OBJ_KEY]], cfg[JV.PROP_FILTER_CONDITION]);
  724. if (compRst) break;
  725. }
  726. }
  727. }
  728. startIdx++;
  729. if (!compRst) {
  730. break; //有不符合条件的数据则退出(这里的判断条件是and关系)
  731. }
  732. }
  733. return compRst;
  734. };
  735. let private_sub_filter_compare = function (dtlItem, subFilters) {
  736. let cmpRst = false;
  737. for (let dtlCfg of subFilters) {
  738. cmpRst = private_filter_compare(dtlItem, dtlCfg);
  739. if (cmpRst) {
  740. if (dtlCfg[JV.PROP_OTHER_SUB_FILTER] && dtlCfg[JV.PROP_OTHER_SUB_FILTER].length > 0) {
  741. cmpRst = private_sub_filter_compare(dtlItem, dtlCfg[JV.PROP_OTHER_SUB_FILTER]);
  742. if (cmpRst) break;
  743. } else {
  744. break;
  745. }
  746. }
  747. }
  748. return cmpRst;
  749. };
  750. for (let item of tempRstArr) {
  751. if (private_filter_compare(item, handleCfg)) {
  752. rstArr.push(item);
  753. }
  754. }
  755. if (handleCfg[JV.PROP_OTHER_SUB_FILTER] && handleCfg[JV.PROP_OTHER_SUB_FILTER].length > 0) {
  756. let newRstArr = [];
  757. for (let dtlItem of rstArr) {
  758. let cmpRst = private_sub_filter_compare(dtlItem, handleCfg[JV.PROP_OTHER_SUB_FILTER]);
  759. if (cmpRst) {
  760. newRstArr.push(dtlItem);
  761. }
  762. }
  763. rstArr = newRstArr;
  764. }
  765. replaceActDataArr(sourceData, rstArr);
  766. // fsUtil.writeObjToFile(sourceData.data, "D:/GitHome/ConstructionCost/tmp/filteredRst.jsp");
  767. }
  768. function adjustData(sourceData, adjustCfg) {
  769. let rstArr = [];
  770. for (let item of getActDataArr(sourceData)) {
  771. if (item._doc) {
  772. rstArr.push(item._doc);
  773. } else {
  774. rstArr.push(item);
  775. }
  776. }
  777. for (let item of adjustCfg[JV.PROP_ADJUST_COLLECTION]) {
  778. for (let rec of rstArr) {
  779. if (item[JV.PROP_ADJUST_ACTION] === "prefix") {
  780. rec[item.key] = item[JV.PROP_ADJUST_ACTION_VAL] + rec[item.key];
  781. } else if (item[JV.PROP_ADJUST_ACTION] === "suffix") {
  782. rec[item.key] = rec[item.key] + item[JV.PROP_ADJUST_ACTION_VAL];
  783. }
  784. }
  785. }
  786. replaceActDataArr(sourceData, rstArr);
  787. }
  788. function componentReplacement(rawDataObj) {
  789. let rationGljData = getModuleDataByKey(rawDataObj.prjData, projectConst.RATION_GLJ),
  790. prjGljData = getModuleDataByKey(rawDataObj.prjData, projectConst.PROJECTGLJ),
  791. gljAssistant = prjGljData.data.gljAssistant;
  792. let connectStrArr = [], dataArr = getActDataArr(rationGljData), rvRGljIds = [], replaceGljItems = [];
  793. for (let idx = 0; idx < dataArr.length; idx++) {
  794. let rationGljItem = dataArr[idx];
  795. if (rationGljItem.type === 301 || rationGljItem.type === 302) {
  796. connectStrArr[0] = rationGljItem.code;
  797. connectStrArr[1] = rationGljItem.name;
  798. connectStrArr[2] = rationGljItem.specs;
  799. connectStrArr[3] = rationGljItem.unit;
  800. connectStrArr[4] = rationGljItem.type;
  801. let mapData = prjGljData.data.mixRatioMap[connectStrArr.join('|-|')];
  802. if (mapData) {
  803. rvRGljIds.push(idx);
  804. let rgItems = [];
  805. replaceGljItems.push(rgItems);
  806. for (let mapItem of mapData) {
  807. let copyItem = {};
  808. rgItems.push(copyItem);
  809. copyItem.ID = `Replace_` + rationGljItem.ID;
  810. copyItem.projectID = rationGljItem.projectID;
  811. copyItem.GLJID = rationGljItem.GLJID;
  812. copyItem.rationID = rationGljItem.rationID;
  813. if (gljAssistant.componentGljIds[COMPONENT_GLJID_PRE + mapItem.glj_id]) {
  814. copyItem.projectGLJID = gljAssistant.componentGljIds[COMPONENT_GLJID_PRE + mapItem.glj_id].id; //关键key
  815. } else {
  816. copyItem.projectGLJID = mapItem.glj_id; //不应该走到这一步,否则就是错误!!!
  817. }
  818. copyItem.rationItemQuantity = rationGljItem.rationItemQuantity;
  819. // copyItem.quantity = rationGljItem.quantity;
  820. copyItem.quantity = rationGljItem.quantity * mapItem.consumption;
  821. copyItem.name = mapItem.name;
  822. copyItem.code = mapItem.code;
  823. copyItem.original_code = mapItem.code;
  824. copyItem.unit = mapItem.unit;
  825. copyItem.specs = mapItem.specs;
  826. copyItem.model = gljAssistant.gljIds['gljId_'+rationGljItem.projectGLJID].model;
  827. copyItem.shortName = mapItem.shortName;
  828. copyItem.billsItemID = rationGljItem.billsItemID;
  829. copyItem.type = mapItem.type; //关键key
  830. }
  831. }
  832. }
  833. }
  834. if (rvRGljIds.length > 0) {
  835. for (let lIdx = rvRGljIds.length - 1; lIdx >= 0; lIdx--) {
  836. dataArr.splice(rvRGljIds[lIdx],1);
  837. }
  838. for (let componentItems of replaceGljItems) {
  839. for (let compItem of componentItems) {
  840. dataArr.push(compItem);
  841. //gljAssistant[COMPONENT_GLJID_PRE + mapItem.glj_id]
  842. }
  843. }
  844. }
  845. }
  846. function moveRationData(rationData, rawDataObj) {
  847. if (rawDataObj) {
  848. // let rationData = getModuleDataByKey(rawDataObj.prjData, projectConst.RATION);
  849. let rationGljData = getModuleDataByKey(rawDataObj.prjData, projectConst.RATION_GLJ);
  850. let prjGljData = getModuleDataByKey(rawDataObj.prjData, projectConst.PROJECTGLJ);
  851. let dummyCode = " ", dummyPRJID = 10101010;
  852. for (let rationItem of getActDataArr(rationData)) {
  853. if (rationItem.type === 2 || rationItem.type === 3) {
  854. //2: 量材(人工/材料/机械/主材/设备) 3:材料(材料/主材/设备)
  855. let copyItem = {};
  856. copyItem.ID = rationItem.ID;
  857. copyItem.projectID = rationItem.projectID;
  858. copyItem.GLJID = rationItem.GLJID;
  859. copyItem.rationID = rationItem.ID;
  860. copyItem.rationItemQuantity = 1;
  861. copyItem.quantity = 1;
  862. // copyItem.specialType_quantity = rationItem.quantity;
  863. copyItem.name = rationItem.name;
  864. if (rationItem.code) {
  865. copyItem.code = rationItem.ID + "_" + rationItem.code;
  866. } else {
  867. copyItem.code = dummyCode;
  868. dummyCode = dummyCode + " ";
  869. }
  870. copyItem.original_code = rationItem.original_code;
  871. copyItem.unit = rationItem.unit;
  872. copyItem.specs = rationItem.specs;
  873. copyItem.shortName = rationItem.shortName;
  874. copyItem.billsItemID = rationItem.billsItemID;
  875. copyItem.type = rationItem.subType;
  876. if (rationItem.projectGLJID) {
  877. copyItem.projectGLJID = rationItem.projectGLJID;
  878. } else {
  879. //add dummy project GLJ
  880. let dummyPrjItem = {};
  881. copyItem.projectGLJID = dummyPRJID;
  882. dummyPrjItem.id = dummyPRJID;
  883. dummyPRJID++;
  884. dummyPrjItem.unit_price = {};
  885. dummyPrjItem.unit_price.base_price = 0;
  886. dummyPrjItem.unit_price.market_price = (rationItem["marketUnitFee"])?rationItem["marketUnitFee"]:0;
  887. dummyPrjItem.quantity = 0;
  888. dummyPrjItem.is_evaluate = 0;
  889. prjGljData.data.gljList.push(dummyPrjItem);
  890. }
  891. rationGljData.data.push(copyItem);
  892. }
  893. }
  894. // fsUtil.writeObjToFile(rationGljData.data, "D:/GitHome/ConstructionCost/tmp/afterMoveGLJ.jsp");
  895. }
  896. }
  897. function getDupGrpKeyVals(sourceData, segKeys) {
  898. let rst = [];
  899. function pushKeyVal(item) {
  900. let tr = {};
  901. for (let i = 0; i < segKeys.length; i++) {
  902. tr[segKeys[i]] = item[segKeys[i]];
  903. }
  904. rst.push(tr);
  905. }
  906. for (let idx = 0; idx < sourceData.length; idx++) {
  907. let itemRec = sourceData[idx];
  908. if (idx === 0) {
  909. pushKeyVal(itemRec);
  910. continue;
  911. }
  912. let hasDiff = false;
  913. for (let i = 0; i < segKeys.length; i++) {
  914. if (itemRec[segKeys[i]] !== sourceData[idx - 1][segKeys[i]]) {
  915. hasDiff = true;
  916. break;
  917. }
  918. }
  919. if (hasDiff) {
  920. pushKeyVal(itemRec);
  921. }
  922. }
  923. return rst;
  924. }
  925. function addDummyData(sourceData, addCfg) {
  926. let rstArr = [], tempRstArr = [];
  927. for (let item of getActDataArr(sourceData)) {
  928. if (item._doc) {
  929. tempRstArr.push(item._doc);
  930. } else {
  931. tempRstArr.push(item);
  932. }
  933. }
  934. for (let item of addCfg[JV.PROP_DUMMY_COLLECTION]) {
  935. let newRecStr = JSON.stringify(item[JV.PROP_DUMMY_VAL]), cacheGrpKeyRecs = null;
  936. if (item[JV.PROP_FREQUENCY] === "OncePerGrp") {
  937. if (!cacheGrpKeyRecs) {
  938. cacheGrpKeyRecs = {};
  939. }
  940. let cacheKey = "";
  941. for (let key of item[JV.PROP_GRP_KEYS]) {
  942. cacheKey += "_" + key;
  943. }
  944. if (!cacheGrpKeyRecs[cacheKey]) {
  945. cacheGrpKeyRecs[cacheKey] = getDupGrpKeyVals(tempRstArr, item[JV.PROP_GRP_KEYS]);
  946. }
  947. for (let kv of cacheGrpKeyRecs[cacheKey]) {
  948. let rec = JSON.parse(newRecStr);
  949. for (let key of item[JV.PROP_GRP_KEYS]) {
  950. rec[key] = kv[key];
  951. }
  952. rstArr.push(rec);
  953. }
  954. } else if (item[JV.PROP_FREQUENCY] === "Once") {
  955. rstArr.push(JSON.parse(newRecStr));
  956. }
  957. }
  958. rstArr = rstArr.concat(tempRstArr);
  959. replaceActDataArr(sourceData, rstArr);
  960. }
  961. function getGLJBizType2018(orgType, orgCode, orgName) {
  962. let rst = orgType;
  963. if (orgType === GLJ_TYPE.Labour) {
  964. rst = 11;
  965. if (orgCode === "000000") rst = 10;
  966. } else if (orgType === GLJ_TYPE.Material || (orgType >= 200 && orgType < 300)) {
  967. //材料
  968. if (orgCode === "000000") {
  969. rst = 200; //2.材料
  970. } else if (orgCode === "000000_1") {
  971. rst = 230; //(1) 计价材料
  972. } else if (orgCode === "000000_2") {
  973. rst = 240; //(2) 其他材料费
  974. } else {
  975. if (orgType === GLJ_TYPE.OTHER_MATERIAL) {
  976. //其他材料
  977. rst = 245;
  978. } else {
  979. //计价材料
  980. rst = 235;
  981. }
  982. }
  983. } else if (orgType === GLJ_TYPE.Machine || (orgType >= 300 && orgType < 400)) {
  984. //机械
  985. if (orgCode === "000000") {
  986. rst = 300; //3.机械
  987. } else if (orgCode === "000000_1") {
  988. rst = 330; //(1) 机上人工
  989. } else if (orgCode === "000000_2") {
  990. rst = 340; //(2) 燃油动力费
  991. } else if (orgCode === "000000_3") {
  992. rst = 350; //(2) 施工机具摊销费
  993. } else {
  994. if (orgType === GLJ_TYPE.MACHINE_LABOUR) {
  995. //机上人工
  996. rst = 335;
  997. } else if (orgType === GLJ_TYPE.FUEL_POWER_FEE) {
  998. //燃油动力费
  999. rst = 345;
  1000. } else if (oprMachines.indexOf(orgType) >= 0) {
  1001. //施工机具摊销费
  1002. rst = 355 + oprMachines.indexOf(orgType);
  1003. }
  1004. }
  1005. }
  1006. return rst;
  1007. }
  1008. function getGLJBizType(orgType, orgCode, orgName) {
  1009. let rst = orgType;
  1010. if (orgName.indexOf("其他材料费") >= 0) {
  1011. rst = 299;
  1012. } else if (orgType === GLJ_TYPE.Labour) {
  1013. rst = 11;
  1014. if (orgCode === "000000") rst = 10;
  1015. } else if (orgType === GLJ_TYPE.Main_Material || orgType === GLJ_TYPE.Equipment) {
  1016. //未计价材料(主材 + 设备)
  1017. rst = 30 + orgType;
  1018. } else if (orgType === GLJ_TYPE.Material || (orgType >= 200 && orgType < 300)) {
  1019. //材料
  1020. if (orgCode === "000000") {
  1021. rst = 20; //2.材料
  1022. } else if (orgCode === "000000_1") {
  1023. rst = 30; //(1) 未计价材料
  1024. } else if (orgCode === "000000_2") {
  1025. rst = 40; //(2) 辅助材料
  1026. } else if (orgCode === "000000_3") {
  1027. rst = 50; //(3) 其他材料费
  1028. } else {
  1029. rst = 45; //到这里就只有辅助材料没有预处理了
  1030. }
  1031. } else if (orgType === GLJ_TYPE.Machine || (orgType >= 300 && orgType < 400)) {
  1032. //机械
  1033. if (orgCode === "000000") {
  1034. rst = 300; //3.机械
  1035. } else if (orgType === GLJ_TYPE.Machine) {
  1036. rst = 300.5;
  1037. } else {
  1038. rst = orgType;
  1039. }
  1040. }
  1041. return rst;
  1042. }
  1043. function sortData(sourceData, sortCfg, prjData) {
  1044. let rst = getActDataArr(sourceData), tempRstArr = [];
  1045. let sortType = sortCfg[JV.PROP_SORT_TYPE];
  1046. let srcData = getActDataArr(sourceData);
  1047. for (let item of srcData) {
  1048. if (item._doc) {
  1049. tempRstArr.push(item._doc);
  1050. } else {
  1051. tempRstArr.push(item);
  1052. }
  1053. }
  1054. function private_normal_sort(destArr, sortKeys) {
  1055. destArr.sort(function(a, b){
  1056. let compRst = 0;
  1057. for (let comp of sortKeys) {
  1058. let reverse = (comp.order === 'ascend')?1:(-1);
  1059. //
  1060. if (a[comp.key] > b[comp.key]) {
  1061. compRst = reverse;
  1062. break;
  1063. } else if (a[comp.key] < b[comp.key]) {
  1064. compRst = -reverse;
  1065. break;
  1066. }
  1067. }
  1068. return compRst;
  1069. });
  1070. }
  1071. function private_parent_sort(parentArr, parentKeys, childArr, childKeys) {
  1072. let tmpRst = {}, rst = [];
  1073. for (let pItem of parentArr) {
  1074. let pKey = "key";
  1075. for (let key of parentKeys) {
  1076. pKey += "_" + pItem[key];
  1077. }
  1078. tmpRst[pKey] = [];
  1079. }
  1080. for (let cItem of childArr) {
  1081. let cKey = "key";
  1082. for (let key of childKeys) {
  1083. cKey += "_" + cItem[key];
  1084. }
  1085. if (tmpRst[cKey]) {
  1086. tmpRst[cKey].push(cItem);
  1087. } else {
  1088. //unknown child value! should be filtered!
  1089. }
  1090. }
  1091. // childArr.splice(0);
  1092. for (let pItem of parentArr) {
  1093. let pKey = "key";
  1094. for (let key of parentKeys) {
  1095. pKey += "_" + pItem[key];
  1096. }
  1097. rst.push(tmpRst[pKey]);
  1098. // for (let rItem of tmpRst[pKey]) {
  1099. // childArr.push(rItem);
  1100. // }
  1101. }
  1102. return rst;
  1103. }
  1104. switch (sortType) {
  1105. case "tree":
  1106. let addLevel = true;
  1107. rst = treeUtil.buildTreeNodeDirectly(tempRstArr, addLevel);
  1108. let newTopArr = [];
  1109. if ((sortCfg[JV.PROP_FILTER_TOP_BILLS_NODES] && sortCfg[JV.PROP_FILTER_TOP_BILLS_NODES].length > 0) ||
  1110. (sortCfg[JV.PROP_FILTER_OTHER_BILLS_NODES] && sortCfg[JV.PROP_FILTER_OTHER_BILLS_NODES].length > 0)) {
  1111. let local_check_bills = function(tItem) {
  1112. let chkDtl = false;
  1113. if (tItem.flags && tItem.flags.length > 0) {
  1114. for (let flagItem of tItem.flags) {
  1115. if (sortCfg[JV.PROP_FILTER_OTHER_BILLS_NODES].indexOf(flagItem.flag) >= 0) {
  1116. newTopArr.push(tItem);
  1117. chkDtl = true;
  1118. break;
  1119. }
  1120. }
  1121. }
  1122. if (!chkDtl && tItem.items && tItem.items.length > 0) {
  1123. for (let dtlItem of tItem.items) {
  1124. local_check_bills(dtlItem);
  1125. }
  1126. }
  1127. };
  1128. for (let topItem of rst) {
  1129. let chkTop = false;
  1130. if (topItem.flags && topItem.flags.length > 0) {
  1131. for (let flagItem of topItem.flags) {
  1132. if (sortCfg[JV.PROP_FILTER_TOP_BILLS_NODES].indexOf(flagItem.flag) >= 0) {
  1133. newTopArr.push(topItem);
  1134. chkTop = true;
  1135. break;
  1136. }
  1137. }
  1138. }
  1139. if (!chkTop && sortCfg[JV.PROP_FILTER_OTHER_BILLS_NODES] && sortCfg[JV.PROP_FILTER_OTHER_BILLS_NODES].length > 0) {
  1140. local_check_bills(topItem);
  1141. }
  1142. }
  1143. } else {
  1144. newTopArr = rst;
  1145. }
  1146. let destArr = [];
  1147. // fsUtil.writeObjToFile(newTopArr, "D:/GitHome/ConstructionCost/tmp/sortedAndFlattedRstBefore.jsp");
  1148. treeUtil.getFlatArray(newTopArr, destArr);
  1149. replaceActDataArr(sourceData, destArr);
  1150. // fsUtil.writeObjToFile(sourceData.data, "D:/GitHome/ConstructionCost/tmp/sortedAndFlattedRst.jsp");
  1151. break;
  1152. case "normal":
  1153. private_normal_sort(tempRstArr, sortCfg[JV.PROP_SORT_KEYS]);
  1154. replaceActDataArr(sourceData, tempRstArr);
  1155. // fsUtil.writeObjToFile(sourceData.data, "D:/GitHome/ConstructionCost/tmp/normalSortedRst.jsp");
  1156. break;
  1157. case "accord_to_parent":
  1158. let pcKey = sortCfg[JV.PROP_PARENT_CHILD_SORT_KEY];
  1159. let parentSrcData = getModuleDataByKey(prjData, pcKey[JV.PROP_PARENT_DATA_KEY]);
  1160. if (parentSrcData) {
  1161. let tempParentArr = [];
  1162. for (let item of getActDataArr(parentSrcData)) {
  1163. if (item._doc) {
  1164. tempParentArr.push(item._doc);
  1165. } else {
  1166. tempParentArr.push(item);
  1167. }
  1168. }
  1169. let sortedRstArr = private_parent_sort(tempParentArr, pcKey[JV.PROP_PARENT_SORT_KEYS], tempRstArr, pcKey[JV.PROP_CHILD_SORT_KEYS]);
  1170. if (sortCfg[JV.PROP_OTHER_SUB_SORT] && sortCfg[JV.PROP_OTHER_SUB_SORT].length > 0) {
  1171. for (let sort of sortCfg[JV.PROP_OTHER_SUB_SORT]) {
  1172. if (sort[JV.PROP_SORT_TYPE] === 'normal') {
  1173. for (let subArr of sortedRstArr) {
  1174. private_normal_sort(subArr, sort[JV.PROP_SORT_KEYS]);
  1175. }
  1176. } else if (sort[JV.PROP_SORT_TYPE] === 'self_define') {
  1177. for (let subArr of sortedRstArr) {
  1178. // console.log(subArr);
  1179. let selfDefFunc = null;
  1180. eval('selfDefFunc = ' + sort[JV.PROP_SORT_TYPE_SELF_DEFINE_LOGIC]);
  1181. subArr.sort(selfDefFunc);
  1182. // console.log(subArr);
  1183. }
  1184. }
  1185. }
  1186. }
  1187. tempRstArr.splice(0);
  1188. for (let item of sortedRstArr) {
  1189. for (let subItem of item) {
  1190. tempRstArr.push(subItem);
  1191. }
  1192. }
  1193. }
  1194. replaceActDataArr(sourceData, tempRstArr);
  1195. break;
  1196. case "self_define":
  1197. if (sortCfg[JV.PROP_SORT_TYPE_SELF_DEFINE_LOGIC]) {
  1198. let selfDefFuncA = null;
  1199. eval('selfDefFuncA = ' + sortCfg[JV.PROP_SORT_TYPE_SELF_DEFINE_LOGIC]);
  1200. // 备注: 因为eval方法的特殊性,不要定义相同变量(这里是‘selfDefFunc’),否则会得到个null
  1201. tempRstArr.sort(selfDefFuncA);
  1202. }
  1203. replaceActDataArr(sourceData, tempRstArr);
  1204. break;
  1205. default:
  1206. //
  1207. }
  1208. return rst;
  1209. }
  1210. function setupMainFunc(obj, prop, ownRawObj) {
  1211. obj[prop] = {};
  1212. obj[prop]["myOwnRawDataObj"] = ownRawObj;
  1213. obj[prop].getProperty = ext_mainGetPropety;
  1214. obj[prop].getFee = ext_mainGetFee;
  1215. }
  1216. function setupFunc(obj, prop, ownRawObj) {
  1217. obj[prop] = {};
  1218. obj[prop]["myOwnRawDataObj"] = ownRawObj;
  1219. obj[prop]["myOwnOrgRawDataObj"] = ownRawObj.data;
  1220. obj[prop].getProperty = ext_getPropety;
  1221. obj[prop].getPropertyByRefId = ext_getPropertyByRefId;
  1222. obj[prop].getFee = ext_getFee;
  1223. obj[prop].getPropertyByForeignId = ext_getPropertyByForeignId;
  1224. obj[prop].getArrayValues = ext_getArrayValues;
  1225. obj[prop].getArrayItemByKey = ext_getArrayItemByKey;
  1226. obj[prop].getPropertyByFlag = ext_getPropertyByFlag;
  1227. obj[prop].getBlank = ext_getBlank;
  1228. if (prop === projectConst.CALC_PROGRAM) obj[prop].getCalcProperty = ext_getCalcProperty;
  1229. if (prop === projectConst.FEERATE) obj[prop].getFeeRate = ext_getFeeRate;
  1230. }
  1231. function assembleFields(fieldList, rstDataArr, $PROJECT) {
  1232. if (fieldList) {
  1233. for (let field of fieldList) {
  1234. shielded_exec_env($PROJECT, field, rstDataArr);
  1235. if ("Precision" in field) {
  1236. if (field["Precision"]["type"] === "fixed") {
  1237. let vrst = eval(field["Precision"]["fixedMapExpression"]);
  1238. if (vrst && vrst.length === 1) {
  1239. field.fixedPrecisionNum = vrst[0];
  1240. vrst.splice(0,1);
  1241. }
  1242. } else if (field["Precision"]["type"] === "flexible") {
  1243. let vrst = eval(field["Precision"]["flexibleMapExpression"]);
  1244. if (vrst && vrst.length === 1) {
  1245. field.flexiblePrecisionRefObj =vrst[0];
  1246. vrst.splice(0,1);
  1247. }
  1248. }
  1249. }
  1250. }
  1251. }
  1252. }
  1253. function shielded_exec_env($PROJECT, $ME, rptDataItemObj) {
  1254. if ($ME[JV.PROP_FIELD_EXP_MAP]) {
  1255. rptDataItemObj.push(eval($ME[JV.PROP_FIELD_EXP_MAP]));
  1256. }
  1257. }
  1258. function getActPropertyVal(firstPropKey, secPropKey, orgObj) {
  1259. let rst = null;
  1260. if (orgObj[firstPropKey]) {
  1261. rst = orgObj[firstPropKey];
  1262. } else if (orgObj[secPropKey]){
  1263. rst = orgObj[secPropKey];
  1264. }
  1265. return rst;
  1266. }
  1267. function getDeepProperty(propKey, orgObj, destArr) {
  1268. let keys = propKey.split(".");
  1269. let dftPropKey = "key", dftPropVal = "value", secDftPropVal = "items";
  1270. let parent = orgObj, lastVal = null;
  1271. for (let key of keys) {
  1272. if (parent instanceof Array) {
  1273. for (let item of parent) {
  1274. if (item[dftPropKey] === key) {
  1275. lastVal = getActPropertyVal(dftPropVal, secDftPropVal, item);
  1276. break;
  1277. }
  1278. }
  1279. } else {
  1280. lastVal = null;
  1281. if (parent[key] !== undefined) {
  1282. lastVal = parent[key];
  1283. } else if (parent[secDftPropVal]){
  1284. for (let item of parent[secDftPropVal]) {
  1285. if (item[dftPropKey] === key) {
  1286. // lastVal = item[dftPropVal];
  1287. lastVal = getActPropertyVal(dftPropVal, secDftPropVal, item);
  1288. break;
  1289. }
  1290. }
  1291. }
  1292. }
  1293. parent = lastVal;
  1294. if (parent === null) break;
  1295. }
  1296. if (destArr && destArr instanceof Array) {
  1297. destArr.push(lastVal);
  1298. }
  1299. }
  1300. function ext_mainGetPropety(propKey) {
  1301. let rst = [], parentObj = this;
  1302. let dtObj = parentObj["myOwnRawDataObj"];
  1303. if (propKey && dtObj) {
  1304. if (dtObj.hasOwnProperty("property")) {
  1305. if (!dtObj["property"][propKey] && dtObj[propKey]) {
  1306. rst.push(dtObj[propKey]);
  1307. } else {
  1308. getDeepProperty(propKey, dtObj["property"], rst);
  1309. }
  1310. } else {
  1311. // rst.push(dtObj[propKey]);
  1312. getDeepProperty(propKey, dtObj, rst);
  1313. }
  1314. }
  1315. return rst;
  1316. }
  1317. function ext_getPropety(propKey) {
  1318. let rst = [], parentObj = this;
  1319. let dtObj = parentObj["myOwnRawDataObj"];
  1320. if (propKey && dtObj) {
  1321. for (let dItem of getActDataArr(dtObj)) {
  1322. let doc = (dItem._doc === null || dItem._doc === undefined)?dItem:dItem._doc;
  1323. if (propKey instanceof Array) {
  1324. //备注:这里的key数组表示取value的优先级
  1325. for (let pi = 0; pi < propKey.length; pi++) {
  1326. if (doc.hasOwnProperty("property")) {
  1327. if (doc["property"].hasOwnProperty(propKey[pi])) {
  1328. rst.push(doc["property"][propKey[pi]]);
  1329. break;
  1330. }
  1331. } else if (doc.hasOwnProperty(propKey[pi])) {
  1332. rst.push(doc[propKey[pi]]);
  1333. break;
  1334. } else {
  1335. let lenBefore = rst.length;
  1336. getDeepProperty(propKey[pi], doc, rst);
  1337. if (rst.length === (lenBefore + 1)) {
  1338. if (rst[lenBefore] !== null && rst[lenBefore] !== undefined && rst[lenBefore] !== "") {
  1339. break;
  1340. } else {
  1341. rst.splice(-1, 1); //删除末尾一条数据,给后面留空间
  1342. }
  1343. }
  1344. }
  1345. if (pi === propKey.length - 1) rst.push('');
  1346. }
  1347. } else {
  1348. if (doc.hasOwnProperty("property") && doc["property"].hasOwnProperty(propKey)) {
  1349. rst.push(doc["property"][propKey]);
  1350. } else if (doc.hasOwnProperty(propKey)) {
  1351. rst.push(doc[propKey]);
  1352. } else {
  1353. // rst.push('');
  1354. getDeepProperty(propKey, doc, rst);
  1355. }
  1356. }
  1357. }
  1358. }
  1359. return rst;
  1360. }
  1361. function ext_getPropertyByRefId(baseKey, refIDKey, propertyKey){
  1362. let rst = [], parentObj = this;
  1363. let dtObj = parentObj["myOwnRawDataObj"];
  1364. let orgDtObj = parentObj["myOwnOrgRawDataObj"];
  1365. if (baseKey && refIDKey && propertyKey && dtObj) {
  1366. for (let dItem of getActDataArr(dtObj)) {
  1367. let doc = (dItem._doc === null || dItem._doc === undefined)?dItem:dItem._doc;
  1368. let tmpRst = doc[baseKey];
  1369. if (typeof tmpRst === "string" && tmpRst[0] === "@") {
  1370. let refKey = tmpRst.slice(1);
  1371. let hasGetRef = false;
  1372. for (let orgDItem of orgDtObj) {
  1373. let oDoc = (orgDItem._doc === null || orgDItem._doc === undefined)?orgDItem:orgDItem._doc;
  1374. if (oDoc[refIDKey] === refKey) {
  1375. rst.push(oDoc[propertyKey]);
  1376. hasGetRef = true;
  1377. break;
  1378. }
  1379. }
  1380. if (!hasGetRef) {
  1381. rst.push(tmpRst);
  1382. }
  1383. } else {
  1384. rst.push(tmpRst);
  1385. }
  1386. }
  1387. }
  1388. return rst;
  1389. }
  1390. function ext_mainGetFee(feeKey, dtlFeeKey) {
  1391. let rst = [];
  1392. let parentObj = this;
  1393. let dtObj = parentObj["myOwnRawDataObj"];
  1394. if ((dtObj) && (feeKey)) {
  1395. if (dtObj.hasOwnProperty("fees")) {
  1396. for (let fee of dtObj["fees"]) {
  1397. if (fee["fieldName"] === feeKey) {
  1398. if (dtlFeeKey) {
  1399. rst.push(fee[dtlFeeKey]);
  1400. } else {
  1401. rst.push(fee["unitFee"]);
  1402. }
  1403. break;
  1404. }
  1405. }
  1406. } else if (dtObj.hasOwnProperty(feeKey)) {
  1407. rst.push(dtObj[feeKey]);
  1408. } else {
  1409. //
  1410. }
  1411. }
  1412. return rst;
  1413. }
  1414. function ext_getFee(feeKey, dtlFeeKey) {
  1415. let rst = [], parentObj = this;
  1416. let dtObj = parentObj["myOwnRawDataObj"];
  1417. if (feeKey && dtObj) {
  1418. for (let dItem of getActDataArr(dtObj)) {
  1419. rst.push(pri_getFee(dItem, feeKey, dtlFeeKey));
  1420. }
  1421. }
  1422. for (let i = 0; i < rst.length; i++) {
  1423. rst[i] = parseFloat(rst[i]);
  1424. }
  1425. return rst;
  1426. }
  1427. function pri_getFee(dItem, feeKey, dtlFeeKey) {
  1428. let rst = 0;
  1429. let hasValue = false;
  1430. if (dItem["fees"]) {
  1431. for (let fee of dItem["fees"]) {
  1432. if (fee["fieldName"] === feeKey) {
  1433. if (dtlFeeKey) {
  1434. rst = fee[dtlFeeKey];
  1435. } else {
  1436. rst = fee["unitFee"];
  1437. }
  1438. hasValue = true;
  1439. break;
  1440. }
  1441. }
  1442. } else if (dItem[feeKey]) {
  1443. hasValue = true;
  1444. rst = parseFloat(dItem[feeKey]);
  1445. } else {
  1446. hasValue = true;
  1447. rst = 0;
  1448. }
  1449. if (!hasValue) {
  1450. rst = 0;
  1451. }
  1452. return rst;
  1453. }
  1454. function ext_getCalcProperty(templateIDs, calcItemKey, calcItemKeyVal, calcItemRstKey){
  1455. let rst = [], parentObj = this; //this should be "calc_program" object
  1456. let dtObj = parentObj["myOwnRawDataObj"];
  1457. let optimizeObj = {};
  1458. let private_getProperty = function (cId) {
  1459. let calcTplObj = optimizeObj["calc_program_" + cId];
  1460. if (!calcTplObj) {
  1461. let templates = (dtObj.data._doc)?dtObj.data._doc.templates:dtObj.data.templates;
  1462. for (let tpl of templates) {
  1463. if (cId === tpl.ID) {
  1464. optimizeObj["calc_program_" + cId] = tpl;
  1465. calcTplObj = tpl;
  1466. break;
  1467. }
  1468. }
  1469. }
  1470. if (calcTplObj) {
  1471. for (let calcItem of calcTplObj.calcItems) {
  1472. if (calcItem[calcItemKey] === calcItemKeyVal) {
  1473. if (calcItem[calcItemRstKey] !== undefined && calcItem[calcItemRstKey] !== null) {
  1474. rst.push(calcItem[calcItemRstKey]);
  1475. } else {
  1476. rst.push(calcItem['feeRate']); //业务特点,如果上述key没有值的话,直接取‘feeRate’的value,省的去改指标定义了
  1477. }
  1478. break;
  1479. }
  1480. }
  1481. }
  1482. };
  1483. if (templateIDs instanceof Array) {
  1484. for (let tplId of templateIDs) {
  1485. private_getProperty(tplId);
  1486. }
  1487. } else {
  1488. private_getProperty(templateIDs);
  1489. }
  1490. optimizeObj = null;
  1491. return rst;
  1492. }
  1493. function ext_getFeeRate(fee_Ids){
  1494. let rst = [], parentObj = this; //this should be "feeRate" object
  1495. let dtObj = parentObj["myOwnRawDataObj"];
  1496. let optimizeObj = {};
  1497. let private_getFeeRate = function (fId) {
  1498. let feeRateItemObj = optimizeObj["fee_rates_" + fId];
  1499. if (!feeRateItemObj) {
  1500. let rates = (dtObj.data._doc)?dtObj.data._doc.rates:dtObj.data.rates;
  1501. for (let feeItem of rates) {
  1502. if (fId === feeItem.ID) {
  1503. optimizeObj["fee_rates_" + fId] = feeItem;
  1504. feeRateItemObj = feeItem;
  1505. break;
  1506. }
  1507. }
  1508. }
  1509. if (feeRateItemObj) {
  1510. rst.push(feeRateItemObj.rate);
  1511. } else {
  1512. rst.push(0);
  1513. }
  1514. };
  1515. if (fee_Ids instanceof Array) {
  1516. for (let fId of fee_Ids) {
  1517. private_getFeeRate(fId);
  1518. }
  1519. } else {
  1520. private_getFeeRate(fee_Ids);
  1521. }
  1522. optimizeObj = null;
  1523. return rst;
  1524. }
  1525. function ext_getArrayValues(itemKey) {
  1526. let rst = [], parentObj = this;
  1527. let dtObj = parentObj["myOwnRawDataObj"];
  1528. let keysArr = itemKey.split(".");
  1529. for (let dataItem of getActDataArr(dtObj)) {
  1530. let itemArr = [];
  1531. if (keysArr.length <= 2) {
  1532. if (dataItem[keysArr[0]] instanceof Array) {
  1533. if (keysArr.length === 2) {
  1534. for (let item of dataItem[keysArr[0]]) {
  1535. itemArr.push(item[keysArr[1]]);
  1536. }
  1537. } else {
  1538. itemArr = itemArr.concat(dataItem[keysArr[0]]);
  1539. }
  1540. } else {
  1541. if (keysArr.length === 2) {
  1542. let subProperty = dataItem[keysArr[0]][keysArr[1]];
  1543. if (subProperty instanceof Array) {
  1544. itemArr = itemArr.concat(subProperty);
  1545. } else {
  1546. itemArr.push(subProperty);
  1547. }
  1548. } else {
  1549. itemArr.push(dataItem[keysArr[0]]);
  1550. }
  1551. }
  1552. }
  1553. rst.push(itemArr);
  1554. }
  1555. return rst;
  1556. }
  1557. function ext_getArrayItemByKey(arrayKey, itemKey, itemKeyValue, itemRstKey){
  1558. let rst = [], parentObj = this;
  1559. let dtObj = parentObj["myOwnRawDataObj"];
  1560. let private_getItemValue = function (arr, dtlItKV) {
  1561. for (let item of arr) {
  1562. if (item[itemKey] === dtlItKV) {
  1563. if (itemRstKey) {
  1564. rst.push(item[itemRstKey]);
  1565. } else {
  1566. rst.push(item);
  1567. }
  1568. break;
  1569. }
  1570. }
  1571. };
  1572. let arr = dtObj[arrayKey];
  1573. if (arr && arr instanceof Array) {
  1574. if (itemKeyValue instanceof Array) {
  1575. for (let dtlItemKeyVal of itemKeyValue) {
  1576. private_getItemValue(arr, dtlItemKeyVal);
  1577. }
  1578. } else {
  1579. private_getItemValue(arr, itemKeyValue);
  1580. }
  1581. }
  1582. }
  1583. function ext_getBlank(dftVal) {
  1584. let rst = [], parentObj = this;
  1585. let dtObj = parentObj["myOwnRawDataObj"];
  1586. if (dtObj) {
  1587. let dtData = getActDataArr(dtObj);
  1588. for (let i = 0; i < dtData.length; i++) {
  1589. if (dftVal !== null && dftVal !== undefined) {
  1590. rst.push(dftVal)
  1591. } else rst.push('');
  1592. }
  1593. }
  1594. return rst;
  1595. }
  1596. function ext_getPropertyByFlag(flagVal, rstKey, dftValIfEmpty) {
  1597. let rst = [], parentObj = this;
  1598. let dtObj = parentObj["myOwnRawDataObj"];
  1599. if (flagVal && rstKey && dtObj) {
  1600. let isArr = (flagVal instanceof Array);
  1601. for (let dItem of getActDataArr(dtObj)) {
  1602. let doc = (dItem._doc)?dItem._doc:dItem;
  1603. if (doc.hasOwnProperty("flags")) {
  1604. let bFlag = false;
  1605. for (let flagItem of doc.flags) {
  1606. if (isArr) {
  1607. bFlag = (flagVal.indexOf(flagItem.flag) >= 0);
  1608. } else {
  1609. if (flagItem.flag === flagVal) {
  1610. bFlag = true;
  1611. }
  1612. }
  1613. if (bFlag) break;
  1614. }
  1615. if (bFlag) {
  1616. let keys = rstKey.split(".");
  1617. if (keys[0] === "fees") {
  1618. rst.push(pri_getFee(doc, "common", keys[1]));
  1619. } else {
  1620. //其他,比如名称什么
  1621. }
  1622. break;
  1623. }
  1624. }
  1625. }
  1626. }
  1627. if (rst.length === 0 && dftValIfEmpty !== null) {
  1628. rst.push(dftValIfEmpty);
  1629. }
  1630. return rst;
  1631. }
  1632. function ext_getPropertyByForeignId(foreignIdVal, adHocIdKey, propKey, dftValIfNotFound) {
  1633. let rst = [], parentObj = this;
  1634. let IdKey = (adHocIdKey)?adHocIdKey:"ID";
  1635. let dtObj = parentObj["myOwnRawDataObj"];
  1636. let splitPKey = propKey.split(".");
  1637. if (foreignIdVal !== null && foreignIdVal !== undefined) {
  1638. let isFound = false;
  1639. if (foreignIdVal instanceof Array) {
  1640. for (let idVal of foreignIdVal) {
  1641. isFound = false;
  1642. let dataArr = getActDataArr(dtObj);
  1643. for (let i = 0; i < dataArr.length; i++) {
  1644. let item = (dataArr[i]._doc)?dataArr[i]._doc:dataArr[i];
  1645. if (item[IdKey] === idVal) {
  1646. if (splitPKey.length > 1) {
  1647. let rstP = null;
  1648. for (let i = 0; i < splitPKey.length; i++) {
  1649. if (i === 0) {
  1650. rstP = item[splitPKey[i]];
  1651. } else {
  1652. if (splitPKey[i].indexOf("[") === 0 && splitPKey[i].indexOf("]") === (splitPKey[i].length - 1)) {
  1653. //考虑数组情况^_^!!!
  1654. } else {
  1655. //
  1656. }
  1657. rstP = rstP[splitPKey[i]];
  1658. }
  1659. }
  1660. rst.push(rstP);
  1661. } else {
  1662. rst.push(item[propKey]);
  1663. }
  1664. isFound = true;
  1665. break;
  1666. }
  1667. }
  1668. if (!isFound) {
  1669. rst.push(dftValIfNotFound);
  1670. }
  1671. }
  1672. } else {
  1673. for (let item of getActDataArr(dtObj)) {
  1674. if (item[IdKey] === foreignIdVal) {
  1675. rst.push(item[propKey]);
  1676. isFound = true;
  1677. break;
  1678. }
  1679. }
  1680. if (!isFound) {
  1681. rst.push(dftValIfNotFound);
  1682. }
  1683. }
  1684. }
  1685. return rst;
  1686. }
  1687. function getActDataArr(dtObj) {
  1688. let rst = null;
  1689. if (dtObj) {
  1690. rst = dtObj.data;
  1691. if (dtObj.moduleName === "projectGLJ") {
  1692. rst = dtObj.data.gljList;
  1693. }
  1694. }
  1695. return rst;
  1696. }
  1697. function replaceActDataArr(dtObj, newArr) {
  1698. if (dtObj.moduleName === "projectGLJ") {
  1699. delete dtObj.data.gljList;
  1700. dtObj.data.gljList = newArr;
  1701. } else {
  1702. delete dtObj.data;
  1703. dtObj.data = newArr;
  1704. }
  1705. }
  1706. module.exports = Rpt_Data_Extractor;