project_spread.js 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date 2024/3/5
  7. * @version
  8. */
  9. const SpreadConst = require('../const/spread');
  10. const JsonFields = [
  11. 'tz_ledger_set', 'tz_ledger_bills_spread', 'tz_ledger_pos_spread',
  12. 'gcl_ledger_set', 'gcl_ledger_bills_spread', 'gcl_ledger_pos_spread',
  13. 'tz_stage_set', 'tz_stage_bills_spread', 'tz_stage_pos_spread',
  14. 'gcl_stage_set', 'gcl_stage_bills_spread', 'gcl_stage_pos_spread',
  15. ];
  16. module.exports = app => {
  17. class ProjectSpread extends app.BaseService {
  18. /**
  19. * 构造函数
  20. *
  21. * @param {Object} ctx - egg全局变量
  22. * @return {void}
  23. */
  24. constructor(ctx) {
  25. super(ctx);
  26. this.tableName = 'project_spread';
  27. }
  28. async loadProjectSpread(id) {
  29. const result = await this.getDataByCondition({ id });
  30. if (result) {
  31. JsonFields.forEach(jf => { if(result[jf]) result[jf] = JSON.parse(result[jf]); });
  32. }
  33. return result;
  34. }
  35. generateSpreadSetting(colSet, emptyBase, BaseSetCol, BaseSpreadColSetting, spreadType = 'bills') {
  36. const spreadSetting = JSON.parse(JSON.stringify(emptyBase));
  37. for (const col of colSet) {
  38. if (!col.valid) continue;
  39. const dc = BaseSetCol.find(x => { return x.key === col.key; });
  40. if (!dc) continue;
  41. const orgBaseCols = BaseSpreadColSetting[col.key];
  42. if (!orgBaseCols) continue;
  43. const baseCols = JSON.parse(JSON.stringify(orgBaseCols));
  44. if (dc.fixed.indexOf('alias') < 0 && col.alias) {
  45. if (baseCols.length === 1) {
  46. if (baseCols[0].aliasFormat) {
  47. baseCols[0].title = baseCols[0].aliasFormat.replace('{%s}', col.alias);
  48. delete baseCols[0].aliasFormat;
  49. } else {
  50. baseCols[0].title = col.alias;
  51. }
  52. } else {
  53. baseCols.forEach(x => {
  54. if (x.aliasFormat) {
  55. x.title = x.aliasFormat.replace('{%s}', col.alias);
  56. delete x.aliasFormat;
  57. }
  58. });
  59. }
  60. }
  61. spreadSetting.cols.push(...baseCols);
  62. }
  63. return spreadSetting;
  64. }
  65. generateRelaSpread(colSetType, colSet) {
  66. const baseSetCol = colSetType.indexOf('stage') > 0 ? SpreadConst.BaseSetCol.Stage : SpreadConst.BaseSetCol.Ledger;
  67. const baseSpreadColSetting = colSetType.indexOf('stage') > 0 ? SpreadConst.BaseSpreadColSetting.Stage : SpreadConst.BaseSpreadColSetting.Ledger;
  68. const billsSpread = this.generateSpreadSetting(colSet, SpreadConst.EmptySpreadSetting[colSetType].bills, baseSetCol, baseSpreadColSetting.bills);
  69. const posSpread = this.generateSpreadSetting(colSet, SpreadConst.EmptySpreadSetting[colSetType].pos, baseSetCol, baseSpreadColSetting.pos, 'pos');
  70. return [billsSpread, posSpread];
  71. }
  72. async initProjectSpread(id) {
  73. const data = JSON.parse(JSON.stringify(SpreadConst.ProjectSpreadTemplate));
  74. [data.tz_ledger_bills_spread, data.tz_ledger_pos_spread] = this.generateRelaSpread('tz_ledger_set', data.tz_ledger_set);
  75. [data.tz_stage_bills_spread, data.tz_stage_pos_spread] = this.generateRelaSpread('tz_stage_set', data.tz_stage_set);
  76. [data.gcl_ledger_bills_spread, data.gcl_ledger_pos_spread] = this.generateRelaSpread('gcl_ledger_set', data.gcl_ledger_set);
  77. [data.gcl_stage_bills_spread, data.gcl_stage_pos_spread] = this.generateRelaSpread('gcl_stage_set', data.gcl_stage_set);
  78. data.id = id;
  79. const updateData = { id };
  80. JsonFields.forEach(jf => { if (data[jf]) updateData[jf] = JSON.stringify(data[jf]) });
  81. const result = await this.db.insert(this.tableName, updateData);
  82. if (result.insertId = data.id) return data;
  83. }
  84. async getProjectSpread(id) {
  85. const curSet = await this.loadProjectSpread(id);
  86. if (curSet) return curSet;
  87. return await this.initProjectSpread(id);
  88. }
  89. async updateProjectSet(id, colSetType, colSet) {
  90. const updateData = { id };
  91. const [billsSpread, posSpread] = this.generateRelaSpread(colSetType, colSet);
  92. updateData[colSetType.replace('_set', '_bills_spread')] = JSON.stringify(billsSpread);
  93. updateData[colSetType.replace('_set', '_pos_spread')] = JSON.stringify(posSpread);
  94. updateData[colSetType] = JSON.stringify(colSet);
  95. await this.db.update(this.tableName, updateData);
  96. }
  97. }
  98. return ProjectSpread;
  99. };