rpt_construct_data_util.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456
  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 treeUtil = require('../../../public/treeUtil');
  10. let projectConst = consts.projectConst;
  11. let projectConstList = consts.projectConstList;
  12. class Rpt_Common{
  13. initialize(Projects) {
  14. this.Projects = Projects;
  15. };
  16. getSerialNo(fieldId, $CURRENT_RPT, $CURRENT_DATA){
  17. let itemSerialNoRec = $JE.F(fieldId, $CURRENT_RPT);
  18. if (itemSerialNoRec) {
  19. itemSerialNoRec[JV.PROP_AD_HOC_DATA] = [];
  20. for (var innerFmlIdx = 0; innerFmlIdx < $CURRENT_DATA[JV.DATA_DETAIL_DATA][0].length; innerFmlIdx++) {
  21. itemSerialNoRec[JV.PROP_AD_HOC_DATA][innerFmlIdx] = (innerFmlIdx + 1);
  22. }
  23. itemSerialNoRec = null;
  24. }
  25. };
  26. }
  27. class Rpt_Data_Extractor {
  28. constructor () {
  29. this.COMMON = new Rpt_Common();
  30. };
  31. initialize(tpl) {
  32. this.rptTpl = tpl;
  33. };
  34. getDataRequestFilter() {
  35. let rst = [];
  36. let tpl = this.rptTpl;
  37. let pri_func_chk_filter = function (field) {
  38. for (let key of projectConstList) {
  39. if (rst.indexOf(key) < 0) {
  40. if (field[JV.PROP_FIELD_EXP_MAP]) {
  41. if (field[JV.PROP_FIELD_EXP_MAP].indexOf('.' + key + '.') >= 0) {
  42. rst.push(key);
  43. if (key === projectConst.RATION_GLJ && (rst.indexOf(projectConst.PROJECTGLJ) < 0)) {
  44. //rst.push(projectConst.PROJECTGLJ);
  45. }
  46. if (key === projectConst.PROJECTGLJ && (rst.indexOf(projectConst.RATION_GLJ) < 0)) {
  47. rst.push(projectConst.RATION_GLJ);
  48. }
  49. }
  50. }
  51. }
  52. }
  53. };
  54. if (tpl[JV.NODE_FIELD_MAP][JV.NODE_DISCRETE_FIELDS]) {
  55. for (let field of tpl[JV.NODE_FIELD_MAP][JV.NODE_DISCRETE_FIELDS]) {
  56. pri_func_chk_filter(field);
  57. }
  58. }
  59. if (tpl[JV.NODE_FIELD_MAP][JV.NODE_MASTER_FIELDS]) {
  60. for (let field of tpl[JV.NODE_FIELD_MAP][JV.NODE_MASTER_FIELDS]) {
  61. pri_func_chk_filter(field);
  62. }
  63. }
  64. if (tpl[JV.NODE_FIELD_MAP][JV.NODE_DETAIL_FIELDS]) {
  65. for (let field of tpl[JV.NODE_FIELD_MAP][JV.NODE_DETAIL_FIELDS]) {
  66. pri_func_chk_filter(field);
  67. }
  68. }
  69. if (tpl[JV.NODE_FIELD_MAP][JV.NODE_MASTER_FIELDS_EX]) {
  70. for (let field of tpl[JV.NODE_FIELD_MAP][JV.NODE_MASTER_FIELDS_EX]) {
  71. pri_func_chk_filter(field);
  72. }
  73. }
  74. if (tpl[JV.NODE_FIELD_MAP][JV.NODE_DETAIL_FIELDS_EX]) {
  75. for (let field of tpl[JV.NODE_FIELD_MAP][JV.NODE_DETAIL_FIELDS_EX]) {
  76. pri_func_chk_filter(field);
  77. }
  78. }
  79. return rst;
  80. };
  81. //--- 装配数据(把收集到的数据,依据报表模板的指示,预处理(如:排序、过滤、合计)及装配到相关指标) ---//
  82. assembleData(rawDataObj) {
  83. let $PROJECT = {"COMMON": {}, "MAIN": {}, "DETAIL": {}};
  84. let tpl = this.rptTpl;
  85. $PROJECT.MAIN["myOwnRawDataObj"] = rawDataObj.prj._doc;
  86. $PROJECT.MAIN.getProperty = ext_mainGetPropety;
  87. $PROJECT.MAIN.getFee = ext_mainGetFee;
  88. $PROJECT.DETAIL.getRationPropertyByID = ext_getRationPropertyByID;
  89. if (tpl[JV.NODE_MAP_DATA_HANDLE_INFO]) {
  90. for (let preHandle of tpl[JV.NODE_MAP_DATA_HANDLE_INFO]) {
  91. let srcData = getModuleDataByKey(rawDataObj.prjData, preHandle[JV.PROP_DATA_KEY]);
  92. switch(preHandle[JV.PROP_HANDLE_TYPE]) {
  93. case JV.PROP_HANDLE_TYPE_SORT:
  94. sortData(srcData, preHandle);
  95. break;
  96. case JV.PROP_HANDLE_TYPE_FILTER:
  97. filterData(srcData, preHandle, rawDataObj.prjData);
  98. break;
  99. case JV.PROP_HANDLE_TYPE_SUM:
  100. summaryData(srcData, preHandle, rawDataObj.prjData);
  101. break;
  102. default:
  103. break;
  104. }
  105. }
  106. }
  107. for (let item of rawDataObj.prjData) {
  108. setupFunc($PROJECT.DETAIL, item.moduleName, item);
  109. }
  110. let rptDataObj = {};
  111. rptDataObj[JV.DATA_DISCRETE_DATA] = [];
  112. rptDataObj[JV.DATA_MASTER_DATA] = [];
  113. rptDataObj[JV.DATA_DETAIL_DATA] = [];
  114. rptDataObj[JV.DATA_MASTER_DATA_EX] = [];
  115. rptDataObj[JV.DATA_DETAIL_DATA_EX] = [];
  116. assembleFields(tpl[JV.NODE_FIELD_MAP][JV.NODE_DISCRETE_FIELDS], rptDataObj[JV.DATA_DISCRETE_DATA], $PROJECT);
  117. // console.log(JV.DATA_DISCRETE_DATA);
  118. // console.log(rptDataObj[JV.DATA_DISCRETE_DATA]);
  119. assembleFields(tpl[JV.NODE_FIELD_MAP][JV.NODE_MASTER_FIELDS], rptDataObj[JV.DATA_MASTER_DATA], $PROJECT);
  120. // console.log(JV.DATA_MASTER_DATA);
  121. // console.log(rptDataObj[JV.DATA_MASTER_DATA]);
  122. assembleFields(tpl[JV.NODE_FIELD_MAP][JV.NODE_DETAIL_FIELDS], rptDataObj[JV.DATA_DETAIL_DATA], $PROJECT);
  123. // console.log(JV.DATA_DETAIL_DATA);
  124. // console.log(rptDataObj[JV.DATA_DETAIL_DATA]);
  125. assembleFields(tpl[JV.NODE_FIELD_MAP][JV.NODE_MASTER_FIELDS_EX], rptDataObj[JV.DATA_MASTER_DATA_EX], $PROJECT);
  126. // console.log(JV.DATA_MASTER_DATA_EX);
  127. // console.log(rptDataObj[JV.DATA_MASTER_DATA_EX]);
  128. assembleFields(tpl[JV.NODE_FIELD_MAP][JV.NODE_DETAIL_FIELDS_EX], rptDataObj[JV.DATA_DETAIL_DATA_EX], $PROJECT);
  129. // console.log(JV.DATA_DETAIL_DATA_EX);
  130. // console.log(rptDataObj[JV.DATA_DETAIL_DATA_EX]);
  131. return rptDataObj;
  132. };
  133. }
  134. function getModuleDataByKey(prjData, key) {
  135. let rst = null;
  136. for (let item of prjData) {
  137. if (item.moduleName === key) {
  138. rst = item;
  139. break;
  140. }
  141. }
  142. return rst;
  143. }
  144. function summaryData(sourceData, handleCfg, prjData){
  145. let rstArr = [], tempRstArr = [];
  146. let curParentPrjData = {};
  147. for (let item of sourceData.data) {
  148. if (item._doc) {
  149. tempRstArr.push(item._doc);
  150. } else {
  151. tempRstArr.push(item);
  152. }
  153. }
  154. let private_get_grp_key = function (item) {
  155. let keys = [];
  156. for (let cfg of handleCfg[JV.PROP_SUM_GROUP_KEYS]) {
  157. if (typeof cfg === "string") {
  158. keys.push(item[cfg]);
  159. } else {
  160. if (!curParentPrjData[cfg["seeking_parent"]]) curParentPrjData[cfg["seeking_parent"]] = getModuleDataByKey(prjData, cfg["seeking_parent"]);
  161. for (let pDataItem of curParentPrjData[cfg["seeking_parent"]].data) {
  162. let data = (pDataItem._doc)?pDataItem._doc:pDataItem;
  163. if (item[cfg["seeking_key"]] === data[cfg["parent_key"]]) {
  164. keys.push(data[cfg["parent_grp_key"]]);
  165. break;
  166. }
  167. }
  168. }
  169. }
  170. return ( "grp_key_" + keys.join('_'));
  171. }
  172. let sumObj = {};
  173. for (let dtl of tempRstArr) {
  174. let grpKey = private_get_grp_key(dtl);
  175. if (sumObj[grpKey] === null || sumObj[grpKey] === undefined) {
  176. sumObj[grpKey] = dtl;
  177. rstArr.push(dtl);
  178. } else {
  179. for (let sumKey of handleCfg[JV.PROP_SUM_SUM_KEYS]) {
  180. if (dtl[sumKey]) {
  181. sumObj[grpKey][sumKey] += dtl[sumKey];
  182. }
  183. }
  184. }
  185. }
  186. delete sourceData.data;
  187. sourceData.data = rstArr;
  188. // fsUtil.wirteObjToFile(sourceData.data, "D:/GitHome/ConstructionCost/tmp/sumRst.js");
  189. }
  190. function filterData(sourceData, handleCfg, prjData) {
  191. let rstArr = [], tempRstArr = [];
  192. for (let item of sourceData.data) {
  193. if (item._doc) {
  194. tempRstArr.push(item._doc);
  195. } else {
  196. tempRstArr.push(item);
  197. }
  198. }
  199. let private_chkVal = function (src, dest, compStr) {
  200. let rst = true;
  201. switch (compStr) {
  202. case "==" :
  203. rst = (src == dest);
  204. break;
  205. case "===" :
  206. rst = (src === dest);
  207. break;
  208. case ">" :
  209. rst = (src > dest);
  210. break;
  211. case ">=" :
  212. rst = (src >= dest);
  213. break;
  214. case "<" :
  215. rst = (src < dest);
  216. break;
  217. case "<=" :
  218. rst = (src <= dest);
  219. break;
  220. case "!=" :
  221. rst = (src != dest);
  222. break;
  223. case "!==" :
  224. rst = (src !== dest);
  225. break;
  226. default:
  227. rst = true;
  228. }
  229. return rst;
  230. }
  231. for (let item of tempRstArr) {
  232. let compRst = true;
  233. let curComparePrjData = null;
  234. for (let cfg of handleCfg[JV.PROP_FILTER_KEY]) {
  235. if (cfg[JV.PROP_FILTER_COMPARE_VAL]) {
  236. //比较key值
  237. compRst = private_chkVal(item[cfg.key], cfg[JV.PROP_FILTER_COMPARE_VAL], cfg[JV.PROP_FILTER_CONDITION]);
  238. } else if (cfg[JV.PROP_FILTER_COMPARE_OBJ] && cfg[JV.PROP_FILTER_COMPARE_OBJ_KEY]){
  239. //通过其他对象来过滤
  240. if (!curComparePrjData) {
  241. curComparePrjData = getModuleDataByKey(prjData, cfg[JV.PROP_FILTER_COMPARE_OBJ]);
  242. }
  243. for (let data of curComparePrjData.data) {
  244. compRst = private_chkVal(item[cfg.key], data[cfg[JV.PROP_FILTER_COMPARE_OBJ_KEY]], cfg[JV.PROP_FILTER_CONDITION]);
  245. if (compRst) break;
  246. }
  247. }
  248. }
  249. if (compRst) {
  250. rstArr.push(item);
  251. }
  252. }
  253. delete sourceData.data;
  254. sourceData.data = rstArr;
  255. // fsUtil.wirteObjToFile(sourceData.data, "D:/GitHome/ConstructionCost/tmp/filteredRst.js");
  256. }
  257. function sortData(sourceData, sortCfg) {
  258. let rst = sourceData.data, tempRstArr = [];
  259. let sortType = sortCfg[JV.PROP_SORT_TYPE];
  260. for (let item of sourceData.data) {
  261. if (item._doc) {
  262. tempRstArr.push(item._doc);
  263. } else {
  264. tempRstArr.push(item);
  265. }
  266. }
  267. switch (sortType) {
  268. case "tree":
  269. rst = treeUtil.buildTreeNodeDirectly(tempRstArr);
  270. let destArr = [];
  271. treeUtil.getFlatArray(rst, destArr);
  272. delete sourceData.data;
  273. sourceData.data = destArr;
  274. // fsUtil.wirteObjToFile(sourceData.data, "D:/GitHome/ConstructionCost/tmp/sortedAndFlattedRst.js");
  275. break;
  276. case "normal":
  277. tempRstArr.sort(function(a, b){
  278. let compRst = 0;
  279. for (let comp of sortCfg[JV.PROP_SORT_KEYS]) {
  280. let reverse = (comp.order === 'ascend')?1:(-1);
  281. if (a[comp.key] > b[comp.key]) {
  282. compRst = reverse;
  283. break;
  284. } else if (a[comp.key] < b[comp.key]) {
  285. compRst = -reverse;
  286. break;
  287. }
  288. }
  289. return compRst;
  290. });
  291. delete sourceData.data;
  292. sourceData.data = tempRstArr;
  293. // fsUtil.wirteObjToFile(sourceData.data, "D:/GitHome/ConstructionCost/tmp/normalSortedRst.js");
  294. break;
  295. default:
  296. //
  297. }
  298. return rst;
  299. }
  300. function setupFunc(obj, prop, ownRawObj) {
  301. obj[prop] = {};
  302. obj[prop]["myOwnRawDataObj"] = ownRawObj;
  303. obj[prop].getProperty = ext_getPropety;
  304. obj[prop].getFee = ext_getFee;
  305. }
  306. function assembleFields(fieldList, rstDataArr, $PROJECT) {
  307. if (fieldList) {
  308. for (let field of fieldList) {
  309. shielded_exec_env($PROJECT, field, rstDataArr);
  310. }
  311. }
  312. }
  313. function shielded_exec_env($PROJECT, $ME, rptDataItemObj) {
  314. if ($ME[JV.PROP_FIELD_EXP_MAP]) {
  315. rptDataItemObj.push(eval($ME[JV.PROP_FIELD_EXP_MAP]));
  316. }
  317. }
  318. function ext_mainGetPropety(propKey) {
  319. let rst = [];
  320. let parentObj = this;
  321. //console.log(this);
  322. let dtObj = parentObj["myOwnRawDataObj"];
  323. if ((dtObj) && (propKey)) {
  324. if (dtObj.hasOwnProperty("property")) {
  325. rst.push(dtObj["property"][propKey]);
  326. } else {
  327. rst.push(dtObj[propKey]);
  328. }
  329. }
  330. return rst;
  331. }
  332. function ext_mainGetFee(feeKey, dtlFeeKey) {
  333. let rst = [];
  334. let parentObj = this;
  335. let dtObj = parentObj["myOwnRawDataObj"];
  336. if ((dtObj) && (feeKey)) {
  337. if (dtObj.hasOwnProperty("fees")) {
  338. for (let fee of dtObj["fees"]) {
  339. if (fee["fieldName"] === feeKey) {
  340. if (dtlFeeKey) {
  341. rst.push(fee[dtlFeeKey]);
  342. } else {
  343. rst.push(fee["unitFee"]);
  344. }
  345. break;
  346. }
  347. }
  348. } else if (dtObj.hasOwnProperty(feeKey)) {
  349. rst.push(dtObj[feeKey]);
  350. } else {
  351. //
  352. }
  353. }
  354. return rst;
  355. }
  356. function ext_getPropety(propKey) {
  357. let rst = [], parentObj = this;
  358. let dtObj = parentObj["myOwnRawDataObj"];
  359. if (propKey && dtObj) {
  360. for (let dItem of dtObj.data) {
  361. let doc = (dItem._doc === null || dItem._doc === undefined)?dItem:dItem._doc;
  362. if (doc.hasOwnProperty("property")) {
  363. rst.push(doc["property"][propKey]);
  364. } else if (doc.hasOwnProperty(propKey)) {
  365. rst.push(doc[propKey]);
  366. } else {
  367. rst.push('');
  368. }
  369. }
  370. }
  371. return rst;
  372. }
  373. function ext_getFee(feeKey, dtlFeeKey) {
  374. let rst = [], parentObj = this;
  375. let dtObj = parentObj["myOwnRawDataObj"];
  376. if (feeKey && dtObj) {
  377. for (let dItem of dtObj.data) {
  378. let hasValue = false;
  379. if (dItem.hasOwnProperty("fees")) {
  380. for (let fee of dItem["fees"]) {
  381. if (fee["fieldName"] === feeKey) {
  382. if (dtlFeeKey) {
  383. rst.push(fee[dtlFeeKey]);
  384. } else {
  385. rst.push(fee["unitFee"]);
  386. }
  387. hasValue = true;
  388. break;
  389. }
  390. }
  391. } else if (dItem.hasOwnProperty(feeKey)) {
  392. hasValue = true;
  393. rst.push(dItem[feeKey]);
  394. } else {
  395. hasValue = true;
  396. rst.push(0);
  397. }
  398. if (!hasValue) {
  399. rst.push(0);
  400. }
  401. }
  402. }
  403. return rst;
  404. }
  405. function ext_getRationPropertyByID(IdVal, propKey) {
  406. let rst = [], me = this;
  407. if (IdVal !== null && IdVal !== undefined && me[projectConst.RATION]) {
  408. let isFound = false;
  409. if (IdVal instanceof Array) {
  410. for (let id of IdVal) {
  411. isFound = false;
  412. for (let item of me[projectConst.RATION]["myOwnRawDataObj"].data) {
  413. if (item.ID === id) {
  414. rst.push(item[propKey]);
  415. isFound = true;
  416. break;
  417. }
  418. }
  419. // if (!isFound) rst.push[null];
  420. }
  421. } else {
  422. for (let item of me[projectConst.RATION]["myOwnRawDataObj"].data) {
  423. if (item.ID === IdVal) {
  424. rst.push(item[propKey]);
  425. isFound = true;
  426. break;
  427. }
  428. }
  429. // if (!isFound) rst.push[null];
  430. }
  431. }
  432. return rst;
  433. }
  434. export default Rpt_Data_Extractor;