filing_template_list.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. 'use strict';
  2. /**
  3. *
  4. * 2024/3/21
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. const FtType = {
  10. org: 0,
  11. add: 1,
  12. };
  13. module.exports = app => {
  14. class FilingTemplateList extends app.BaseService {
  15. /**
  16. * 构造函数
  17. *
  18. * @param {Object} ctx - egg全局变量
  19. * @return {void}
  20. */
  21. constructor(ctx) {
  22. super(ctx);
  23. this.tableName = 'filing_template_list';
  24. this.FtType = FtType;
  25. }
  26. async getOriginTemplate() {
  27. return await this.getDataByCondition({ ft_type: FtType.org });
  28. }
  29. async getAllTemplate(pid) {
  30. const sql = `SELECT * FROM ${this.tableName} WHERE ft_type = ${FtType.org} OR project_id = ? ORDER BY create_time asc`;
  31. return await this.db.query(sql, [pid]);
  32. }
  33. /**
  34. * 保存/新增数据
  35. *
  36. * @param {Object} name - 模板名称
  37. * @param {String} id - 存在则为保存,反之新增
  38. * @return {boolean} - 操作结果
  39. */
  40. async save(name, id = '') {
  41. if (id) {
  42. const result = await this.defaultUpdate({ id, name });
  43. return [result.affectedRows > 0, id];
  44. } else {
  45. const conn = await this.db.beginTransaction();
  46. try {
  47. const newTemplate = {
  48. id: this.uuid.v4(), project_id: this.ctx.session.sessionProject.id,
  49. user_id: this.ctx.session.sessionUser.accountId,
  50. name: name || '新增XXX模板库', ft_type: FtType.add,
  51. };
  52. await conn.insert(this.tableName, newTemplate);
  53. await this.ctx.service.filingTemplate.initTemplate(conn, newTemplate);
  54. await conn.commit();
  55. return [true, newTemplate.id];
  56. } catch (err) {
  57. this.ctx.log(err);
  58. await conn.rollback();
  59. return [false, ''];
  60. }
  61. }
  62. }
  63. /**
  64. * 删除模板
  65. *
  66. * @param {string} id - 删除的id
  67. * @return {Boolean} - 返回删除的结果
  68. */
  69. async delete(id) {
  70. const conn = await this.db.beginTransaction();
  71. try {
  72. await conn.delete(this.tableName, { id });
  73. await conn.delete(this.ctx.service.filingTemplate.tableName, { temp_id: id });
  74. await conn.commit();
  75. return true;
  76. } catch (error) {
  77. this.ctx.log(error);
  78. await conn.rollback();
  79. return false;
  80. }
  81. }
  82. async reset(id) {
  83. const template = await this.getDataById(id);
  84. const conn = await this.db.beginTransaction();
  85. try {
  86. await conn.delete(this.ctx.service.filingTemplate.tableName, { temp_id: id });
  87. await this.ctx.service.filingTemplate.initTemplate(conn, template);
  88. await conn.commit();
  89. } catch(err) {
  90. await conn.rollback();
  91. throw err;
  92. }
  93. }
  94. }
  95. return FilingTemplateList;
  96. };